CopyOnWriteArrayList是读多写少场景下的线程安全集合,写操作复制整个数组,读操作无锁直接访问;2. 适合监听器列表、配置缓存等低频修改场景,不适用高频写或强一致需求;3. 相比ArrayList非线程安全,Vector和synchronizedList读写全加锁低吞吐,它读高效但可能读到旧数据快照。

CopyOnWriteArrayList 是 Java 并发包(java.util.concurrent)中一个线程安全的动态数组实现,它的核心特点是:**写操作(add、set、remove 等)会复制整个底层数组,读操作则直接在原数组上进行,不加锁。**
为什么叫 “Copy-On-Write”?
这个名字直译是“写时复制”。它的工作机制很简单:
- 每次执行修改操作(比如
add()、remove()、set())时,不是直接修改原数组,而是先创建一个新数组,把原数组内容复制过去,再在新数组上做修改,最后用新数组原子性地替换掉旧数组。 - 所有读操作(如
get()、iterator()、size())全程不加锁,也不复制,直接访问当前引用的数组——哪怕这个数组正在被其他线程更新。
适合什么场景?
它最适合读多写少且对实时一致性要求不高的并发场景,比如:
- 监听器列表(Observer 模式):大量线程频繁遍历注册的监听器,但新增/移除监听器的操作很少。
- 配置项缓存、白名单、状态标记集合等:读取非常频繁,变更极少。
⚠️ 注意:它不适合写频繁或对数据强一致性敏感的场景。因为写操作开销大(复制整个数组),而且读操作看到的可能是“过期快照”——例如迭代过程中另一个线程删除了元素,迭代器也不会抛 ConcurrentModificationException,也不会反映这次删除。
立即学习“Java免费学习笔记(深入)”;
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~