1. 并发调⽤场景下CopyOnWriteArrayList添加元素是如何保证线程安全?
源码解析
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23/**被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详解内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复