LinkedHashSet底层源码分析

LinkedHashSet在底层使用LinkedHashMap来保持插入顺序,当调用add方法时,实际上执行的是HashMap的put方法,但由于LinkedHashMap对put方法的重写,通过linkNodeLast方法设置了节点的before和after指针,从而实现了有序性。
摘要由CSDN通过智能技术生成

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;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值