CopyOnWriteArrayList详解

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();
	 }
 }
  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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值