并发集合5-CopyOnWriteArraySet源码分析

前言

CopyOnWriteArraySet是通过代理CopyOnWriteArrayList的方法来实现的,add操作是通过调用CopyOnWriteArrayList的addxxx方法来实现set集合不重复元素特性的。

定义

并发集合5-CopyOnWriteArraySet源码分析_第1张图片

构造器

默认构造器


并发集合5-CopyOnWriteArraySet源码分析_第2张图片

集合构造器


并发集合5-CopyOnWriteArraySet源码分析_第3张图片

add方法如何保证set集合的特性

add方法调用CopyOnWriteArrayList的addIfAbsent方法实现set.add


CopyOnWriteArrayList中的addIfAbsent方法:集合中没有指定元素则添加
并发集合5-CopyOnWriteArraySet源码分析_第4张图片

私有方法
并发集合5-CopyOnWriteArraySet源码分析_第5张图片

需要 注意indexOf方法是通过equal方法比较是否存在的。

在addIfAbsent方法中,我们发现对addIfAbsent方法的优化,即利用array数组的线程可见性,无锁获取一个快照,如果在这个快照中有指定元素则返回false,如果不含有指定元素,需要调用addIfAbsent(E e, Object[] snapshot)方法加锁进行遍历并将e添加在新创建的数组尾部。即避免了在含有重复元素的情况下加锁遍历的过程。

方法列表

并发集合5-CopyOnWriteArraySet源码分析_第6张图片

总结

CopyOnWriteArraySet和CopyOnWriteArrayList性能特性一样,只是CopyOnWriteArraySet的元素不允许重复。

你可能感兴趣的:(并发集合5-CopyOnWriteArraySet源码分析)