ArrayList
众所周知ArrayList是非线程安全的,在多线程的情况下,向list插入数据的时候,可能会造成数据丢失的情况.并且一个线程在遍历List,另一个线程修改List,会报ConcurrentModificationException(并发修改异常)错误.
Vector
Vector是一个线程安全的List,但是它的线程安全实现方式是对所有操作都加上了synchronized关键字,这种方式严重影响效率.所以并不推荐使用Vector.
Collections.synchronizedList(List list)
要实现List的线程安全,可以使用 Collections.synchronizedList,先看一下它的使用方法.
List<String> list = Collections.synchronizedList(new ArrayList<String>());
list.add("1");
list.add("2");
list.add("3");
synchronized (list) {
Iterator i = list.iterator(); // Must be in synchronized block
while (i.hasNext()) {
//foo(i.next());
System.out.println(i.next());
}
}
为什么add()不需要synchronized,而遍历的时候需要加synchronized?
首先来看下Collections.synchronizedList的源码
Collections.synchronizedList的源码
public static <T> List<T> synchronizedList(List<T> list) {
return (list