Java的集合内容很丰富,可以称为Java集合框架,所谓框架者,必然存在着层次关系,在面向对象的世界里,层次意味着接口,抽象类及实现了接口或者继承自抽象类的类。接口的出现很好理解,因为不同类型的集合都有一些通用的方法。一图胜千言:Java集合的关系图如下:
注意:很多人想当然地认为Collection接口是所有集合的顶级接口,后来通过读Java API 6 发现,Map和Collection没有血缘关系,真是大跌眼镜!
我们来看看API中对Collection和Map的接口及其子类的描述:
通过这两个图我们可以发现,Map和Collection确实是不同的。集合中有的类可以允许重复元素,有的不可以,下面有一个列表进行了总结。
List是有序集合,而Set和Map则不一定。以Tree开头的都是有序的。而以Hash开头的,是用hash实现的,性能上比用二叉树实现的Tree**要好。
关于同步问题,一般而言,非同步的类,性能比同步的要好。我们建议用Collections.synchronizedCollection(Collection<T> c)方法去处理原本非同步的类,在不丢失性能的前提下,实现同步。Java1.5提供了ConcurrentHashMap,适用于高并发的线程安全实现。
下面是几个例子:
<pre class="java" name="code">Set set = new HashSet();
set.add("111");
set.add("222");
set.add("333");
set.add("333"); // can not be added
System.out.println("size = "+set.size());
for(Iterator it = set.iterator();it.hasNext();){
System.out.println(it.next());
}
List list = new ArrayList();
list.add("bbb");
list.add("ccc");
list.add("ddd");
list.add("ddd");
System.out.println("size = "+list.size());
for(Iterator it = list.iterator();it.hasNext();){
System.out.println(it.next());
}
Vector v = new Vector();
v.add("v1");
v.add("v2");
v.add("v3");
v.add("v3");
for(Iterator it = v.iterator();it.hasNext();){
System.out.println(it.next());
}
List arrayList = new ArrayList();
arrayList.add("Index");
arrayList.add("Index");
arrayList.add("Index");
for(Iterator it = arrayList.iterator();it.hasNext();){
System.out.println(it.next());
}