Java集合-Collection
首先看两张关系图:
-
Collection
Collection 是最基本的集合接口,一个 Collection 代表一组 Object,即 Collection 的元素, Java不提供直接继承自Collection的类,只提供继承于的子接口(如List和set)。
Collection 接口存储一组不唯一,无序的对象。
-
List-有序可重复列表
List接口是一个有序的 Collection,使用此接口能够精确的控制每个元素插入的位置,能够通过索引(元素在List中位置,类似于数组的下标)来访问List中的元素,第一个元素的索引为 0,而且允许有相同的元素。
List 接口存储一组不唯一,有序(插入顺序)的对象。
-
Set-无序不重复列表
Set 具有与 Collection 完全一样的接口,只是行为上不同,Set 不保存重复的元素。
Set 接口存储一组唯一,无序的对象。
-
Map-键值对列表(key不可重复)
Map 接口存储一组键值对象,提供key(键)到value(值)的映射。主要就是以上这些基本的区别,各种子类就是加入一些特殊的存储结构,链表、哈希树、二叉树;Link链表的插入和删除效率高,查询效率低,List列表的查询效高,插入和删除效率低,两者恰好互补。
-
Iterator-迭代器
Java Iterator(迭代器)不是一个集合,它是一种用于访问集合的方法,可用于迭代 ArrayList 和 HashSet 等集合。Iterator 是 Java 迭代器最简单的实现,ListIterator 是 Collection API 中的接口, 它扩展了 Iterator 接口,可以反向迭代。
List<String> list = new ArrayList<String>();
list.add("1");
list.add("2");
list.add("3");
list.add("4");
list.add("5");
list.add("6");
Iterator<String> iterator = list.iterator();
//iterator.hasNext()如果存在元素的话返回true
while(iterator.hasNext()) {
//iterator.next()返回迭代的下一个元素
System.out.println(iterator.next());
}
- Comparable-对象排序
实现了Comparable接口的类的对象的列表或数组可以通过Collections.sort或Arrays.sort进行自动排序。 - Comparator-对象比较
通过新建比较器来让通过比较器来进行排序和分组。比Comparable 更复杂 ,但是更加灵活。
再就是Map的几个子类关于线程的区别: