ConcurrentSkipListSet底層是經過ConcurrentNavigableMap來實現的,它是一個有序的線程安全的集合。java
它的源碼比較簡單,跟經過Map實現的Set基本是一致,只是多了一些取最近的元素的方法。安全
// 實現了NavigableSet接口,並無所謂的ConcurrentNavigableSet接口 public class ConcurrentSkipListSet<E> extends AbstractSet<E> implements NavigableSet<E>, Cloneable, java.io.Serializable { private static final long serialVersionUID = -2479143111061671589L; // 存儲使用的map private final ConcurrentNavigableMap<E,Object> m; // 初始化 public ConcurrentSkipListSet() { m = new ConcurrentSkipListMap<E,Object>(); } // 傳入比較器 public ConcurrentSkipListSet(Comparator<? super E> comparator) { m = new ConcurrentSkipListMap<E,Object>(comparator); } // 使用ConcurrentSkipListMap初始化map // 並將集合c中全部元素放入到map中 public ConcurrentSkipListSet(Collection<? extends E> c) { m = new ConcurrentSkipListMap<E,Object>(); addAll(c); } // 使用ConcurrentSkipListMap初始化map // 並將有序Set中全部元素放入到map中 public ConcurrentSkipListSet(SortedSet<E> s) { m = new ConcurrentSkipListMap<E,Object>(s.comparator()); addAll(s); } // ConcurrentSkipListSet類內部返回子set時使用的 ConcurrentSkipListSet(ConcurrentNavigableMap<E,Object> m) { this.m = m; } // 克隆方法 public ConcurrentSkipListSet<E> clone() { try { @SuppressWarnings("unchecked") ConcurrentSkipListSet<E> clone = (ConcurrentSkipListSet<E>) super.clone(); clone.setMap(new ConcurrentSkipListMap<E,Object>(m)); return clone; } catch (CloneNotSupportedException e) { throw new InternalError(); } } /* ---------------- Set operations -------------- */ // 返回元素個數 public int size() { return m.size(); } // 檢查是否爲空 public boolean isEmpty() { return m.isEmpty(); } // 檢查是否包含某個元素 public boolean contains(Object o) { return m.containsKey(o); } // 添加一個元素 // 調用map的putIfAbsent()方法 public boolean add(E e) { return m.putIfAbsent(e, Boolean.TRUE) == null; } // 移除一個元素 public boolean remove(Object o) { return m.remove(o, Boolean.TRUE); } // 清空全部元素 public void clear() { m.clear(); } // 迭代器 public Iterator<E> iterator() { return m.navigableKeySet().iterator(); } // 降序迭代器 public Iterator<E> descendingIterator() { return m.descendingKeySet().iterator(); } /* ---------------- AbstractSet Overrides -------------- */ // 比較相等方法 public boolean equals(Object o) { // Override AbstractSet version to avoid calling size() if (o == this) return true; if (!(o instanceof Set)) return false; Collection<?> c = (Collection<?>) o; try { // 這裏是經過兩次兩層for循環來比較 // 這裏是有很大優化空間的,參考上篇文章CopyOnWriteArraySet中的彩蛋 return containsAll(c) && c.containsAll(this); } catch (ClassCastException unused) { return false; } catch (NullPointerException unused) { return false; } } // 移除集合c中全部元素 public boolean removeAll(Collection<?> c) { // Override AbstractSet version to avoid unnecessary call to size() boolean modified = false; for (Object e : c) if (remove(e)) modified = true; return modified; } /* ---------------- Relational operations -------------- */ // 小於e的最大元素 public E lower(E e) { return m.lowerKey(e); } // 小於等於e的最大元素 public E floor(E e) { return m.floorKey(e); } // 大於等於e的最小元素 public E ceiling(E e) { return m.ceilingKey(e); } // 大於e的最小元素 public E higher(E e) { return m.higherKey(e); } // 彈出最小的元素 public E pollFirst() { Map.Entry<E,Object> e = m.pollFirstEntry(); return (e == null) ? null : e.getKey(); } // 彈出最大的元素 public E pollLast() { Map.Entry<E,Object> e = m.pollLastEntry(); return (e == null) ? null : e.getKey(); } /* ---------------- SortedSet operations -------------- */ // 取比較器 public Comparator<? super E> comparator() { return m.comparator(); } // 最小的元素 public E first() { return m.firstKey(); } // 最大的元素 public E last() { return m.lastKey(); } // 取兩個元素之間的子set public NavigableSet<E> subSet(E fromElement, boolean fromInclusive, E toElement, boolean toInclusive) { return new ConcurrentSkipListSet<E> (m.subMap(fromElement, fromInclusive, toElement, toInclusive)); } // 取頭子set public NavigableSet<E> headSet(E toElement, boolean inclusive) { return new ConcurrentSkipListSet<E>(m.headMap(toElement, inclusive)); } // 取尾子set public NavigableSet<E> tailSet(E fromElement, boolean inclusive) { return new ConcurrentSkipListSet<E>(m.tailMap(fromElement, inclusive)); } // 取子set,包含from,不包含to public NavigableSet<E> subSet(E fromElement, E toElement) { return subSet(fromElement, true, toElement, false); } // 取頭子set,不包含to public NavigableSet<E> headSet(E toElement) { return headSet(toElement, false); } // 取尾子set,包含from public NavigableSet<E> tailSet(E fromElement) { return tailSet(fromElement, true); } // 降序set public NavigableSet<E> descendingSet() { return new ConcurrentSkipListSet<E>(m.descendingMap()); } // 可分割的迭代器 @SuppressWarnings("unchecked") public Spliterator<E> spliterator() { if (m instanceof ConcurrentSkipListMap) return ((ConcurrentSkipListMap<E,?>)m).keySpliterator(); else return (Spliterator<E>)((ConcurrentSkipListMap.SubMap<E,?>)m).keyIterator(); } // 原子更新map,給clone方法使用 private void setMap(ConcurrentNavigableMap<E,Object> map) { UNSAFE.putObjectVolatile(this, mapOffset, map); } // 原子操做相關內容 private static final sun.misc.Unsafe UNSAFE; private static final long mapOffset; static { try { UNSAFE = sun.misc.Unsafe.getUnsafe(); Class<?> k = ConcurrentSkipListSet.class; mapOffset = UNSAFE.objectFieldOffset (k.getDeclaredField("m")); } catch (Exception e) { throw new Error(e); } } }
能夠看到,ConcurrentSkipListSet基本上都是使用ConcurrentSkipListMap實現的,雖然取子set部分是使用ConcurrentSkipListMap中的內部類,可是這些內部類其實也是和ConcurrentSkipListMap相關的,它們返回ConcurrentSkipListMap的一部分數據。併發
(1)ConcurrentSkipListSet底層是使用ConcurrentNavigableMap實現的;ide
(2)ConcurrentSkipListSet有序的,基於元素的天然排序或者經過比較器肯定的順序;源碼分析
(3)ConcurrentSkipListSet是線程安全的;優化
Set | 有序性 | 線程安全 | 底層實現 | 關鍵接口 | 特色 |
---|---|---|---|---|---|
HashSet | 無 | 否 | HashMap | 無 | 簡單 |
LinkedHashSet | 有 | 否 | LinkedHashMap | 無 | 插入順序 |
TreeSet | 有 | 否 | NavigableMap | NavigableSet | 天然順序 |
CopyOnWriteArraySet | 有 | 是 | CopyOnWriteArrayList | 無 | 插入順序,讀寫分離 |
ConcurrentSkipListSet | 有 | 是 | ConcurrentNavigableMap | NavigableSet | 天然順序 |
從中咱們能夠發現一些規律:this