Java集合学习--集合总结
一、ArrayList与Vector
ArrayList与Vector很多地方大同小异,Vector现在已经基本不再使用。具体的管理如下:
1.ArrayList与Vector都实现了List接口,底层都是基于动态数组实现。
2.ArrayList与Vector底层数组初始大小均为10。
3.ArrayList非线程安全,Vector中方法都是synchronized方法,进行了同步处理。
4.ArrayList扩容机制是扩大为原来的1.5倍,Vector扩容,默认扩大为原来的2倍。
二、HashMap与HashTable
1.均实现Map接口,底层主要数据接口是散列表,hash冲突的时候处理方式都是链表,但是HashMap在1.8后进行大量的优化,引入红黑树。
2.HashMap的初始容量大小为16,加载因子为0.75,HashTable默认初始容量为11,默认加载因子为0.75
Hashtable不要求底层数组的容量一定要为2的整数次幂,而HashMap则要求一定为2的整数次幂。
3.Hashtable中key和value都不允许为null,而HashMap中key和value都允许为null
4.HashMap的扩容机制是扩大为原来的2倍,HashTable扩大为原来的2倍+1;
5.确定一个键值对在散列表中的位置,HashTable是 int hash = key.hashCode();int index = (hash & 0x7FFFFFFF) % tab.length;即将hash值转正值后进行length的取模
HashMap是int hash = key.hashCode()) ^ (h >>> 16);int i = (n - 1) & hash
三、ArrayList与LinkedList
1.均实现List接口,都非线程安全。
2.ArrayList实现RandomAccess接口,支持快速查找和二分查找,LinkedList实现Deque接口,可用作队列。
3.底层实现不同,ArrayList主要是借助动态数组实现,LinkedList则是双向链表。
4.ArrayList扩容,扩大为原来的1.5倍,LinkedList则不需要进行扩容,在内存足够的前提下,容量不限。
5.对比与LinkedList,ArrayList的查找效率高,插入删除效率不足。
四、HashMap,LinkedHashMap,TreeMap
1.均实现Map接口,存储键值对。均非线程安全
2.LinkedHashMap继承HashMap,具有HashMap的所有特性,同样允许key和value为null。底层实现主要是散列表,链表,红黑树;TreeMap主要是通过红黑树实现。
3.HashMap是无序的,LinkedHashMap通过一个双向链表维护key-value的插入顺序,TreeMap默认是根据key的字典顺序升序排序。
4.TreeMap的查询、插入、删除效率均没有HashMap高,一般只有要对key排序时才使用TreeMap
5.TreeMap的key不能为null,而HashMap和LinkedHashMap的key可以为null。
五、HashSet、LinkedHashSet和TreeSet
1.Hashset的实现借助HashMap
public HashSet() {
        map = new HashMap<>();
}
2.LinkedHashSet的底层实现是LinkedHashMap
3.TreeSet的实现基于TreeMap 
public TreeSet() {
    this(new TreeMap<E,Object>());
}
set相当于是只存储了key的Map,理解了Map的相关实现类,set的相关实现类水到渠成。
Java集合学习--集合总结的更多相关文章
- Java 集合学习--集合概述
		
一.集合框架 集合,通常也叫容器,java中有多种方式保存对象,集合是java保存对象(对象的引用)的方式之一,之前学习的数组是保存对象的最有效的方式,但是数组却存在一个缺陷,数组的大小是固定的,但是 ...
 - JAVA基础学习-集合三-Map、HashMap,TreeMap与常用API
		
森林森 一份耕耘,一份收获 博客园 首页 新随笔 联系 管理 订阅 随笔- 397 文章- 0 评论- 78 JAVA基础学习day16--集合三-Map.HashMap,TreeMap与常用A ...
 - Java基础学习--集合
		
集合 List集合的特点 1.有序的数据集合,存储元素和取出元素的顺序是一致的(存储123,取出123) 2.有索引,包含了一些带索引的方法 3.允许存储重复的元素 List接口中带索引的方法 add ...
 - java基础学习——集合
		
-------|List: 有存储顺序, 可重复-----------|ArrayList: 数组实现, 查找快, 增删慢,由于是数组实现, 在增和删的时候会牵扯到数组增容, 以及拷贝元素. 所以慢. ...
 - 有关JAVA基础学习中的集合讨论
		
很高兴能在这里认识大家,我也是刚刚接触后端开发的学习者,相信很多朋友在学习中都会遇到很多头疼的问题,希望我们都能够把问题分享出来,把自己的学习思路整理出来,我们一起探讨一起成长. 今天我 ...
 - 转:深入Java集合学习系列:HashSet的实现原理
		
0.参考文献 深入Java集合学习系列:HashSet的实现原理 1.HashSet概述: HashSet实现Set接口,由哈希表(实际上是一个HashMap实例)支持.它不保证set 的迭代顺序:特 ...
 - Java基础学习笔记十五  集合、迭代器、泛型
		
Collection 集合,集合是java中提供的一种容器,可以用来存储多个数据. 在前面的学习中,我们知道数据多了,可以使用数组存放或者使用ArrayList集合进行存放数据.那么,集合和数组既然都 ...
 - 2019/3/4  java集合学习(二)
		
java集合学习(二) 在学完ArrayList 和 LinkedList之后,基本已经掌握了最基本的java常用数据结构,但是为了提高程序的效率,还有很多种特点各异的数据结构等着我们去运用,类如可以 ...
 - 2019/3/2周末 java集合学习(一)
		
Java集合学习(一) ArraysList ArraysList集合就像C++中的vector容器,它可以不考虑其容器的长度,就像一个大染缸一 样,无穷无尽的丢进去也没问题.Java的数据结构和C有 ...
 
随机推荐
- Android 进价5_自定义广播 通过广播更新ListView的适配器 下载管理
			
1.在处理下载管理时,服务在后台运行,下载完成后要更新listview列表的按钮,将“下载”改成“打开”这样一个功能. 在Activity里面写一个静态内部类,继承广播.其中属性text_button ...
 - 利用来JS控制页面控件显示和隐藏有两种方法
			
利用来JS控制页面控件显示和隐藏有两种方法,两种方法分别利用HTML的style中的两个属性,两种方法的不同之处在于控件隐藏后是否还在页面上占空位. 方法一: 1 2 document.getEle ...
 - 从C语言的volatile关键字,了解C#的volatile机制(转载)
			
C#中有一个关键字volatile,一直不太明白到底什么时候才用它,只知道在多线程操作同一个变量的时候要使用volatile关键字,下面看到了一篇C语言关于volatile关键字的介绍,写的很不错,其 ...
 - Flex入坑指南
			
弹性布局flex是一个几年前的CSS属性了,说它解放了一部分生产力不为过.至少解放了不少CSS布局相关的面试题 :) 之前网上流行的各种XX布局,什么postion: absolute+margin, ...
 - Knowledge Point 20180305 详解精度问题
			
1.1 精度与基本数据类型运算的深度解析 我们在探讨Java基本数据类型时多次提到过精度的问题,那么计算机中的精度究竟是什么样的,为什么我们有时候的计算和我们预期的不同呢?下面我们通过精度来了解: 1 ...
 - 工具 | Axure基础操作 No.2
			
不废话了,直接如之前一样上操作图才是正道. 1.设置文本类型为密码或者文件类型 可以在属性中也选择最大长度制定长度. 如果设置类型为文件,在浏览器中就会自动变成选择本地文件的按钮. 2.文本框提示文字 ...
 - java servlet数据库查询并将数据显示到jsp页面
			
需要的jar包:mysql-connector-java.jar build path只是个jar包的引用,部署的时候想不丢包最好还是手动拷贝到对应项目的lib文件下. 在try{}中定义的变量为局部 ...
 - centos7中nginx的搭建
			
./nginx 启动服务./nginx -s stop 关闭服务./nginx -s reload 重新加载配置文件 首先我们应当安装一个依赖的软件包: yum install gcc-c++yum ...
 - TinyMCE插件:Filemanager [4.x-6.x] 图片自动添加水印
			
上传图片程序(filemanager/upload.php) 在if (!empty($_FILES) && $upload_files)有一个move_uploaded_file() ...
 - ubuntu下安装应用(搜狗输入法)