赞
踩
ArrayList
,HashSet
,HashMap
和线程安全之CopyOnWriteArrayList
,CopyOnWriteArraySet
,ConcurrentHashMap
ArrayList
和线程安全之CopyOnWriteArrayList
测试代码:
public static void listNotSafe() {
List<String> list = new ArrayList<>();
for (int i = 1; i <= 30 ; i++) {
new Thread(()->{
list.add(UUID.randomUUID().toString().substring(0,6));
System.out.println(list);
},String.valueOf(i)).start();
}
编译结果:
使用如下:
public static void listNotSafe() {
List<String> list = new CopyOnWriteArrayList<>();
for (int i = 1; i <= 30 ; i++) {
new Thread(()->{
list.add(UUID.randomUUID().toString().substring(0,6));
System.out.println(list);
},String.valueOf(i)).start();
}
编译结果:
源码部分如下
add(E e)
方法public boolean add(E e) {
final ReentrantLock lock = this.lock;
lock.lock();
try {
Object[] elements = getArray();
int len = elements.length;
Object[] newElements = Arrays.copyOf(elements, len + 1);
newElements[len] = e;
setArray(newElements);
return true;
} finally {
lock.unlock();
}
}
CopyOnWrite容器
即写时复制的容器。往一个容器添加元素的时候,不直接往当前容器Object[ ]添加,而是先将当前容器Object[ ]进行Copy,复制出一个新的容器Object[] newElements,然后往新的容器Object[ ] newElements里添加元素,添加完元素之后,再将原容器的引用指向新的容器 setArray(newElements)。Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。