LinkedHashSet底层实际使用的是LinkedHashMap。
public LinkedHashSet() {
super(16, .75f, true);
}
// 点击super进去
HashSet(int initialCapacity, float loadFactor, boolean dummy) {
map = new LinkedHashMap<>(initialCapacity, loadFactor);
}
linkedHashSet的add方法
public boolean add(E e) {
return map.put(e, PRESENT)==null;
}
点击add发现调用的还是Hashmap的put方法,Hashmap本身是无序的,那为什么调用Hashmap的put方法会变成有序的呢?
查看Hashmap源码若为单节点或者为链表时,都采用了newNode方法,进入newNode方法,发现返回的只是一个Node节点,并没有前后指针,那是怎么实现前后指针的呢?
其实上图中有最左侧有一个小箭头,实际是LinkedHashMap对此方法做个重写,点击小箭头进入下图。
// 上图中调用了linkNodeLast,则为处理前后指针的
private void linkNodeLast(LinkedHashMap.Entry<K,V> p) {
LinkedHashMap.Entry<K,V> last = tail;
tail = p;
if (last == null)
head = p;
else {
p.before = last;
last.after = p;
}
}