CopyOnWriteArrayList内部工作原理剖析

CopyOnWriteArrayList是JDK1.5引入的线程安全的ArrayList,适用于读多写少的场景。它通过在修改时复制底层数组来确保线程安全,而非直接修改原数组。在添加元素时,会加锁、复制旧数组、在新数组中添加元素,然后用新数组替换旧数组。读取操作不加锁,可能存在数据延迟。
摘要由CSDN通过智能技术生成

CopyOnWriteArrayList内部工作原理剖析

CopyOnWriteArrayList是由Doug Lea在JDK1.5引入的一个并发工具类,CopyOnWriteArrayList其实线程安全的ArrayList,但又有点不一样 和HashMap和ConcurrentHashMap的关系有点类似。所有的修改操作(add/set等)都会将底层依赖的数组拷贝一份并在其之上修改,但是我们知道数组的拷贝是一个比较耗时的操作,因此通常用于读多写少的场景下,例如随机访问、遍历等。

工作原理

首先CopyOnWriteArrayList有哪些重要的域, 首先有个可重入锁用于修改(add/set等)时保证其线程安全型,另外有一个array数组用于存储实际的数据,并用volatile修饰,保证可见性。

1
2
3
4
5
6
7
8
9
10

final transient ReentrantLock lock = new ReentrantLock();
private transient volatile Object[] array;

final Object[] getArray() {
    return array;
}

final void setArray(Object[] a) {
    array = a;
}

ADD()工作机制

如果看过ArrayList的代码,会发现CopyOnWriteArrayList的会简单很多。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值