JAVA集合篇之LinkedHashSet底层源码(JDK8)

LinkedHashSet的图表如下:

LinkedHashSet是HashSet的子类,底层实现为:数组+双向链表

LinkedHashSet也具有去重功能,并且元素是有序的。

构造方法如下:

执行空构造

LinkedHashSet<Object> hashSet = new LinkedHashSet<>();

分析:

/**
 * Constructs a new, empty linked hash set with the default initial
 * capacity (16) and load factor (0.75).
 */
public LinkedHashSet() {
    super(16, .75f, true); //调用父类(HashSet)的构造器
}

创建了一个LinkedHashMap,初始容量16,加载因子0.75

HashSet(int initialCapacity, float loadFactor, boolean dummy) {
        map = new LinkedHashMap<>(initialCapacity, loadFactor);
    }
public LinkedHashMap(int initialCapacity, float loadFactor) {
        super(initialCapacity, loadFactor);
        accessOrder = false;
    }
public HashMap(int initialCapacity, float loadFactor) {
        if (initialCapacity < 0)
            throw new IllegalArgumentException("Illegal initial capacity: " +
                                               initialCapacity);
        if (initialCapacity > MAXIMUM_CAPACITY)
            initialCapacity = MAXIMUM_CAPACITY;
        if (loadFactor <= 0 || Float.isNaN(loadFactor))
            throw new IllegalArgumentException("Illegal load factor: " +
                                               loadFactor);
        this.loadFactor = loadFactor;
        this.threshold = tableSizeFor(initialCapacity); //这里计算出来=16
    }

调用 hashSet.add(123); 添加元素,会执行以下方法,底层也是走的hashMap的put方法

public boolean add(E e) {
    return map.put(e, PRESENT)==null;
}

// 以下方法的添加逻辑同上一篇博客,这里略过

/**
 * Implements Map.put and related methods
 *
 * @param hash hash for key
 * @
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值