集合
集合框架围绕一组标准接口而设计,我们可以直接使用这些接口的标准实现,也可以通过这些接口实现自己的集合。
以下是百度的一张集合框架结构图:
从上图我们可以看出,集合主要分为两个不同的容器,一个是Collection,另一个是Map。
Collection 接口又有 3 种子类型,List、Set 和 Queue,再下面是一些抽象类,最后是具体实现类,常用的有 ArrayList、LinkedList、HashSet、LinkedHashSet、HashMap、LinkedHashMap 等等。
Collection
最基本的集合接口,一个 Collection 代表一组 Object,即 Collection 的元素, Java不提供直接继承自Collection的类,只提供继承于的子接口(如List和set)。
Collection 接口存储一组不唯一,无序的对象。
Collection 的常用方法:
boolean add(E o)
添加元素到此 collection 中,如果 collection 由于此方法的调用而发生改变,则返回true。
boolean addAll(Collection extends E> c)
将指定 collection 中的所有元素都添加到此 collection 中。
void clear()
移除此 collection 中的所有元素。
boolean contains(Object o)
当且仅当此 collection 至少包含一个满足 (o==null ? e==null : o.equals(e)) 的元素 e 时才返回 true。
boolean containsAll(Collection> c)
如果此 collection 包含指定 collection 中的所有元素,则返回 true。
boolean isEmpty()
如果此 collection 不包含元素,则返回 true。
boolean remove(Object o)
如果此 collection 包含一个或多个满足 (o==null ? e==null : o.equals(e)) 的元素 e,则移除这样的元素。如果 collection 由于此方法的调用而发生改变),则返回 true。
boolean remove(Collection> c)
移除此 collection 中那些也包含在指定 collection 中的所有元素(移除交集)。此调用返回后,collection 中将不包含任何与指定 collection 相同的元素。
boolean retainAll(Collection> c)
仅保留此 collection 中那些也包含在指定 collection 的元素(保留交集)。换句话说,移除此 collection 中未包含在指定 collection 中的所有元素。
int size()
返回此 collection 中的元素数。
T[] toArray(T[] a)
返回包含此 collection 中所有元素的数组;返回数组的运行时类型与指定数组的运行时类型相同。如果指定的数组能容纳该 collection,则返回包含此 collection 元素的数组。否则,将根据指定数组的运行时类型和此 collection 的大小分配一个新数组。
Iterator iterator()
返回在此 collection 的元素上进行迭代的迭代器。关于元素返回的顺序没有任何保证(除非此 collection 是某个能提供保证顺序的类实例)。
实例示范:
//接口不能被实例化,只能实例化其实现类
Collection huLuWa = newArrayList();//给collection添加元素
huLuWa.add("大娃");
huLuWa.add("二娃");
huLuWa.add("三娃");//size方法获取个数
System.out.println(huLuWa.size()+"个葫芦娃:"+huLuWa);
Collection huLu= newArrayList();//addAll 方法添加huLuWa中所有元素
huLu.addAll(huLuWa);
System.out.println("葫芦里有:"+huLu);//remove 方法移除元素“大娃”
huLu.remove("大娃");
System.out.println("葫芦里有:"+huLu);
huLu.add("蛇精");
System.out.println("葫芦里有:"+huLu);//removeAll 方法移除huLu和huLuWa的交集
huLu.removeAll(huLuWa);
System.out.println("葫芦里有:"+huLu);
huLu.add("三娃");
System.out.println("葫芦里有:"+huLu);//retainAll 方法保留交集
huLu.retainAll(huLuWa);
System.out.println("葫芦里有:"+huLu);//使用迭代器遍历所有元素
for(Iterator wa=huLuWa.iterator();wa.hasNext();) {
System.out.println(wa.next());
}
打印结果为:
3个葫芦娃:[大娃, 二娃, 三娃]
葫芦里有:[大娃, 二娃, 三娃]
葫芦里有:[二娃, 三娃]
葫芦里有:[二娃, 三娃, 蛇精]
葫芦里有:[蛇精]
葫芦里有:[蛇精, 三娃]
葫芦里有:[三娃]
大娃
二娃
三娃