概述
1. 并发调⽤场景下CopyOnWriteArrayList添加元素是如何保证线程安全?
源码解析
/**被volatile关键字修饰,保证这个数组的有序性。 */
private transient volatile Object[] array;
public boolean add(E e) {
final ReentrantLock lock = this.lock;
// 加锁
lock.lock();
try {
// 获取原有数组元素
Object[] elements = getArray();
int len = elements.length;
// copy原有数组,⻓度加1⽤于存放新添加的元素
Object[] newElements = Arrays.copyOf(elements, len + 1);
// 直接赋值,放到新数组末尾
newElements[len] = e;
// 替换原有数组
setArray(newElements);
return true;
} finally {
// finally中释放锁,确保出现异常情况下也能释放锁
lock.unlock();
}
}
- 加锁;
- 进行增加或删除元素
- 解锁。
通过加锁和释放锁的方式保证线程安全
2. 并发调⽤场景下CopyOnWriteArrayList既然已经加锁了为什么还要用volatile关键字修饰数组
主要就是防止进行指令重排,保证数组并发修改的有序性。
volatile关键字详解请看下文:
https://www.cnblogs.com/cxy2020/p/12951333.html
https://blog.csdn.net/weixin_39724194/article/details/107385004
https://blog.csdn.net/weixin_39724194/article/details/107451450
最后
以上就是忧郁秋天为你收集整理的CopyOnWriteArrayList详解的全部内容,希望文章能够帮你解决CopyOnWriteArrayList详解所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复