CopyOnWriteArrayList是线程安全的List实现,适用于读多写少场景。1. 通过写时复制机制保证线程安全:写操作加锁并复制底层数组,读操作无锁直接访问。2. volatile数组引用确保修改对其他线程可见。3. 读操作高效,但写操作因复制开销大,性能较低。4. 迭代器基于快照,具有弱一致性,不抛ConcurrentModificationException。5. 不适用于实时性要求高或数据量大的写场景。示例中多个读线程与单个写线程并发操作安全执行,无需额外同步。
Java中的CopyOnWriteArrayList本身就是线程安全的,不需要额外实现。它属于java.util.concurrent包,专为并发场景设计,适用于读多写少的情况。
CopyOnWriteArrayList是一种线程安全的List实现。它的核心机制是:每当有写操作(如add、set、remo
ve)时,都会创建底层数组的一个新副本,修改在副本上进行,完成后原子地替换原数组。
这种策略保证了读操作无需加锁,非常适合读远多于写的并发场景。
示例代码:
import java.util.concurrent.CopyOnWriteArrayList;
public class SafeListExample {
private static final CopyOnWriteArrayList list =
new CopyOnWriteArrayList<>();
public static void main(String[] args) {
// 多个线程同时读
Runnable reader = () -> {
for (String s : list) {
System.out.println("Read: " + s);
}
};
// 单个线程写
list.add("item1");
list.add("item2");
// 启动多个读线程
for (int i = 0; i < 5; i++) {
new Thread(reader).start();
}
}
}
基本上就这些。如果你需要一个天然线程安全且读多写少的List,CopyOnWriteArrayList开箱即用,无需自己实现同步逻辑。