美文网首页
并发集合5-CopyOnWriteArraySet源码分析

并发集合5-CopyOnWriteArraySet源码分析

作者: zhanglbjames | 来源:发表于2017-06-21 18:16 被阅读0次

前言

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的元素不允许重复。

相关文章

网友评论

      本文标题:并发集合5-CopyOnWriteArraySet源码分析

      本文链接:https://www.haomeiwen.com/subject/ktkfqxtx.html