我是靠谱客的博主 忧郁秋天,这篇文章主要介绍CopyOnWriteArrayList详解,现在分享给大家,希望可以做个参考。

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(); } }
  1. 加锁;
  2. 进行增加或删除元素
  3. 解锁。
    通过加锁和释放锁的方式保证线程安全

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详解内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(85)

评论列表共有 0 条评论

立即
投稿
返回
顶部