集 合
Collection 接口的接口 对象的集合(单列集合)
├——-List
接口:元素按进入先后有序保存,可重复
│—————-├ LinkedList
接口实现类, 链表, 插入删除, 没有同步, 线程不安全
│—————-├ ArrayList
接口实现类, 数组, 随机访问, 没有同步, 线程不安全
│—————-└ Vector
接口实现类 数组, 同步, 线程安全
│ ———————-└ Stack
是Vector类的实现类
└——-Set 接口: 仅接收一次,不可重复,并做内部排序
├—————-└HashSet
使用hash表(数组)存储元素
│————————└ LinkedHashSet
链表维护元素的插入次序
└ —————-TreeSet
底层实现为二叉树,元素排好序
Map 接口 键值对的集合 (双列集合)
├———Hashtable
接口实现类, 同步, 线程安全
├———HashMap
接口实现类 ,没有同步, 线程不安全-
│—————–├ LinkedHashMap
双向链表和哈希表实现
│—————–└ WeakHashMap
├ ——–TreeMap
红黑树对所有的key进行排序
└———IdentifyHashMap
List:
ArrayList
:底层数据结构是数组,查询快,增删慢,线程不安全,效率高,可以存储重复元素
LinkedList
底层数据结构是链表,查询慢,增删快,线程不安全,效率高,可以存储重复元素
Vector
:底层数据结构是数组,查询快,增删慢,线程安全,效率低,可以存储重复元素
Set
是一个内部有序且不含重复元素的容器
同时因为其是一个抽象的接口:所以不能直接实例化一个set对象。(Set s = new Set() )错误。
HashSet
底层用数组存储数据,默认初始化容量16,加载因子0.75。元素无序且唯一,线程不安全,效率高,可以存储null元素,元素的唯一性是靠所存储元素类型是否重写hashCode()和equals()方法来保证的.
LinkedHashSet
底层数据结构采用链表和哈希表共同实现,链表保证了元素的顺序与存储顺序一致,哈希表保证了元素的唯一性。线程不安全,效率高。
TreeSet
底层数据结构采用二叉树来实现,元素唯一且已经排好序
Map
主要用于存储键值对,不允许键相同,允许值相同
Hashmap
访问速度较快,访问速度与容量有关,HashMap最多只允许一条记录的键为Null;允许多条记录的值为 Null,不支持线程同步,可以使用ConcurrentHashMap来实现同步
Hashtable
写入速度较慢 不允许键或者值为null 支持线程同步
LinkedHashMap
访问速度与实际数据有关,Hashmap的子类,保存了记录的插入顺序
TreeMap
将保存的记录按照键排序(默认升序)