JDK
版本:AdoptOpenJDK 11.0.10+9
1 基本概念
CopyOnWriteArraySet
是为 “读多写少” 场景设计的并发容器,其特点如下:
- 适用于高并发场景
- 列表型容器
- 没有重复的数据
- 利用 “写时复制” 思想,保证读/写同时进行不会冲突
- 只有当多个线程同时进行写操作的时候,才需要同步
- 内部使用
CopyOnWriteArrayList
对象实现功能
2 内部原理
CopyOnWriteArraySet
内部引用了一个 CopyOnWriteArrayList
对象,以 “组合” 方式,委托CopyOnWriteArrayList
对象实现了所有API
功能。
public class CopyOnWriteArraySet<E> extends AbstractSet<E>
implements java.io.Serializable {
private static final long serialVersionUID = 5457747651344034263L;
// 内部引用的CopyOnWriteArrayList对象
private final CopyOnWriteArrayList<E> al;
// 构造函数
public CopyOnWriteArraySet() {
al = new CopyOnWri