//我们这里将 ArrayList集合作为 Collection 的实现类
Collection collection = newArrayList();//添加元素
collection.add("Tom");
collection.add("Bob");//删除指定元素
collection.remove("Tom");//删除所有元素
Collection c = newArrayList();
c.add("Bob");
collection.removeAll(c);//检测是否存在某个元素
collection.contains("Tom");//判断是否为空
collection.isEmpty();//利用增强for循环遍历集合
for(Object obj : collection){
System.out.println(obj);
}//利用迭代器 Iterator
Iterator iterator =collection.iterator();while(iterator.hasNext()){
Object obj=iterator.next();
System.out.println(obj);
}
③、List :有序,可以重复的集合。
由于 List 接口是继承于 Collection 接口,所以基本的方法如上所示。
1、List 接口的三个典型实现:
①、List list1 = new ArrayList();
底层数据结构是数组,查询快,增删慢;线程不安全,效率高
②、List list2 = new Vector();
底层数据结构是数组,查询快,增删慢;线程安全,效率低,几乎已经淘汰了这个集合
③、List list3 = new LinkedList();
底层数据结构是链表,查询慢,增删快;线程不安全,效率高
怎么记呢?我们可以想象:
数组就像身上编了号站成一排的人,要找第10个人很容易,根据人身上的编号很快就能找到。但插入、删除慢,要望某个位置插入或删除一个人时,后面的人身上的编号都要变。当然,加入或删除的人始终末尾的也快。
链表就像手牵着手站成一圈的人,要找第10个人不容易,必须从第一个人一个个数过去。但插入、删除快。插入时只要解开两个人的手,并重新牵上新加进来的人的手就可以。删除一样的道理。
2、除此之外,List 接口遍历还可以使用普通 for 循环进行遍历,指定位置添加元素,替换元素等等。
1 //产生一个 List 集合,典型实现为 ArrayList
2 List list = newArrayList();3 //添加三个元素
4 list.add("Tom");5 list.add("Bob");6 list.add("Marry");7 //构造 List 的迭代器
8 Iterator it =list.iterator();9 //通过迭代器遍历元素
10 while(it.hasNext()){11 Object obj =it.next();12 //System.out.println(obj);
13 }14
15 //在指定地方添加元素
16 list.add(2, 0);17
18 //在指定地方替换元素
19 list.set(2, 1);20
21 //获得指定对象的索引
22 int i=list.indexOf(1);23 System.out.println("索引为:"+i);24
25 //遍历:普通for循环
26 for(int j=0;j

④、Set:典型实现 HashSet()是一个无序,不可重复的集合

1、Set hashSet = new HashSet();

①、HashSet:不能保证元素的顺序;不可重复;不是线程安全的;集合元素可以为 NULL;

②、其底层其实是一个数组,存在的意义是加快查询速度。我们知道在一般的数组中,元素在数组中的索引位置是随机的,元素的取值和元素的位置之间不存在确定的关系,因此,在数组中查找特定的值时,需要把查找值和一系列的元素进行比较,此时的查询效率依赖于查找过程中比较的次数。而 HashSet 集合底层数组的索引和值有一个确定的关系:index=hash(value),那么只需要调用这个公式,就能快速的找到元素或者索引。

③、对于 HashSet: 如果两个对象通过 equals() 方法返回 true,这两个对象的 hashCode 值也应该相同。

1、当向HashSet集合中存入一个元素时,HashSet会先调用该对象的hashCode()方法来得到该对象的hashCode值,然后根据hashCode值决定该对象在HashSet中的存储位置

1.1、如果 hashCode 值不同,直接把该元素存储到 hashCode() 指定的位置

1.2、如果 hashCode 值相同,那么会继续判断该元素和集合对象的 equals() 作比较

1.2.1、hashCode 相同,equals 为 true,则视为同一个对象,不保存在 hashSet()中

1.2.2、hashCode 相同,equals 为 false,则存储在之前对象同槽位的链表上,这非常麻烦,我们应该约束这种情况,即保证:如果两个对象通过 equals() 方法返回 true,这两个对象的 hashCode 值也应该相同。

注意:每一个存储到 哈希 表中的对象,都得提供 hashCode() 和 equals() 方法的实现,用来判断是否是同一个对象

对于 HashSet 集合,我们要保证如果两个对象通过 equals() 方法返回 true,这两个对象的 hashCode 值也应该相同。

常见的 hashCode()算法:

javaee项目集合 java集合汇总_List

2、Set linkedHashSet = new LinkedHashSet();

①、不可以重复,有序

因为底层采用 链表 和 哈希表的算法。链表保证元素的添加顺序,哈希表保证元素的唯一性

3、Set treeSet = new TreeSet();

TreeSet:有序;不可重复,底层使用 红黑树算法,擅长于范围查询。

*  如果使用 TreeSet() 无参数的构造器创建一个 TreeSet 对象, 则要求放入其中的元素的类必须实现 Comparable 接口所以, 在其中不能放入 null 元素

*  必须放入同样类的对象.(默认会进行排序) 否则可能会发生类型转换异常.我们可以使用泛型来进行限制

javaee项目集合 java集合汇总_java 集合 总结 表_02

* 自动排序:添加自定义对象的时候,必须要实现 Comparable 接口,并要覆盖 compareTo(Object obj) 方法来自定义比较规则

如果 this > obj,返回正数 1

如果 this < obj,返回负数 -1

如果 this = obj,返回 0 ,则认为这两个对象相等

*  两个对象通过 Comparable 接口 compareTo(Object obj) 方法的返回值来比较大小, 并进行升序排列

javaee项目集合 java集合汇总_javaee项目集合_03

*  定制排序: 创建 TreeSet 对象时, 传入 Comparator 接口的实现类. 要求: Comparator 接口的 compare 方法的返回值和 两个元素的 equals() 方法具有一致的返回值

*  当需要把一个对象放入 TreeSet 中,重写该对象对应的 equals() 方法时,应保证该方法与 compareTo(Object obj) 方法有一致的结果

以上三个 Set 接口的实现类比较:

共同点:1、都不允许元素重复

2、都不是线程安全的类,解决办法:Set set = Collections.synchronizedSet(set 对象)

不同点:

HashSet:不保证元素的添加顺序,底层采用 哈希表算法,查询效率高。判断两个元素是否相等,equals() 方法返回 true,hashCode() 值相等。即要求存入 HashSet 中的元素要覆盖 equals() 方法和 hashCode()方法

LinkedHashSet:HashSet 的子类,底层采用了 哈希表算法以及 链表算法,既保证了元素的添加顺序,也保证了查询效率。但是整体性能要低于 HashSet

TreeSet:不保证元素的添加顺序,但是会对集合中的元素进行排序。底层采用 红-黑 树算法(树结构比较适合范围查询)

⑤、Map:key-value 的键值对,key 不允许重复,value 可以

1、严格来说 Map 并不是一个集合,而是两个集合之间 的映射关系。

2、这两个集合没每一条数据通过映射关系,我们可以看成是一条数据。即 Entry(key,value)。Map 可以看成是由多个 Entry 组成。

3、因为 Map 集合即没有实现于 Collection 接口,也没有实现 Iterable 接口,所以不能对 Map 集合进行 for-each 遍历。

javaee项目集合 java集合汇总_链表_04

Map 的常用实现类:

javaee项目集合 java集合汇总_java 集合 总结 表_05

⑥、Map 和 Set 集合的关系

1、都有几个类型的集合。HashMap 和 HashSet ,都采 哈希表算法;TreeMap 和 TreeSet 都采用 红-黑树算法;LinkedHashMap 和 LinkedHashSet 都采用 哈希表算法和红-黑树算法。

2、分析 Set 的底层源码,我们可以看到,Set 集合 就是 由 Map 集合的 Key 组成。

javaee项目集合 java集合汇总_List_06