LinkedHashSet 是在HashSet 基础上可以保持插入顺序的一种Set 集合。
是直接继承了HashSet ,而HashSet 又是HashMap 包装了一层,而LinkedHashMap 是HashMap 的子类,所以HashSet 的实现其实是依赖了LinkedHashMap 。
构造方法
总共有四个构造方法,会发现其实是调用到了HashSet 中一个特殊的构造方法中,这个方法初始化的不是HashMap 而是LinkedHashMap 。
public LinkedHashSet(int initialCapacity, float loadFactor) { super(initialCapacity, loadFactor, true); } public LinkedHashSet(int initialCapacity) { super(initialCapacity, .75f, true); } public LinkedHashSet() { super(16, .75f, true); } public LinkedHashSet(Collection<? extends E> c) { super(Math.max(2*c.size(), 11), .75f, true); addAll(c); } HashSet(int initialCapacity, float loadFactor, boolean dummy) { map = new LinkedHashMap<>(initialCapacity, loadFactor); } 这三个方法在LinkedHashSet中都没有重写,直接使用的是HashSet 中的,最终调用到HashMap 中,而初始化的时候因为初始化的是LinkedHashMap ,所以底层既可以保证唯一性又可以维护插入的顺序,也是依靠双向链表实现。
LinkedHashSet 就是在HashMap、HashSet和LinkedHashMap 的基础上进行了下封装,没有加任何变化。