前言
CopyOnWriteArraySet是通过代理CopyOnWriteArrayList的方法来实现的,add操作是通过调用CopyOnWriteArrayList的addxxx方法来实现set集合不重复元素特性的。
定义
构造器
默认构造器
集合构造器
add方法如何保证set集合的特性
add方法调用CopyOnWriteArrayList的addIfAbsent方法实现set.add
CopyOnWriteArrayList中的addIfAbsent方法:集合中没有指定元素则添加
私有方法
需要注意indexOf方法是通过equal方法比较是否存在的。
在addIfAbsent方法中,我们发现对addIfAbsent方法的优化,即利用array数组的线程可见性,无锁获取一个快照,如果在这个快照中有指定元素则返回false,如果不含有指定元素,需要调用addIfAbsent(E e, Object[] snapshot)方法加锁进行遍历并将e添加在新创建的数组尾部。即避免了在含有重复元素的情况下加锁遍历的过程。
方法列表
总结
CopyOnWriteArraySet和CopyOnWriteArrayList性能特性一样,只是CopyOnWriteArraySet的元素不允许重复。