继承体系
可以看到,LinkedHashSet直接继承自HashSet进行实现,这个关系和 LinkedHashMap-> HashMap一致。
构造函数
LinkedHashSet的构造函数有四个,本质上的都是调用了父类的非public构造方法,将导致产生一个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);
}
// java.util.HashSet
HashSet(int initialCapacity, float loadFactor, boolean dummy) {
map = new LinkedHashMap<>(initialCapacity, loadFactor);
}
总结
LinkedHashSet所有能力都来自父类,在构造器内调用父类产生LinkedHashMap作为真正存储的对象。当前类内除了覆盖spliterator方法之外没有任何添加代码。