真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

死磕java集合之LinkedHashSet源碼分析-創(chuàng)新互聯(lián)

問(wèn)題

(1)LinkedHashSet的底層使用什么存儲(chǔ)元素?

站在用戶的角度思考問(wèn)題,與客戶深入溝通,找到泌陽(yáng)網(wǎng)站設(shè)計(jì)與泌陽(yáng)網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名注冊(cè)、雅安服務(wù)器托管、企業(yè)郵箱。業(yè)務(wù)覆蓋泌陽(yáng)地區(qū)。

(2)LinkedHashSet與HashSet有什么不同?

(3)LinkedHashSet是有序的嗎?

(4)LinkedHashSet支持按元素訪問(wèn)順序排序嗎?

簡(jiǎn)介

上一節(jié)我們說(shuō)HashSet中的元素是無(wú)序的,那么有沒(méi)有什么辦法保證Set中的元素是有序的呢?

答案是當(dāng)然可以。

我們今天的主角LinkedHashSet就有這個(gè)功能,它是怎么實(shí)現(xiàn)有序的呢?讓我們來(lái)一起學(xué)習(xí)吧。

源碼分析

LinkedHashSet繼承自HashSet,讓我們直接上源碼來(lái)看看它們有什么不同。

package java.util;

// LinkedHashSet繼承自HashSet
public class LinkedHashSet
    extends HashSet
    implements Set, Cloneable, java.io.Serializable {

    private static final long serialVersionUID = -2851667679971038690L;

    // 傳入容量和裝載因子
    public LinkedHashSet(int initialCapacity, float loadFactor) {
        super(initialCapacity, loadFactor, true);
    }

    // 只傳入容量, 裝載因子默認(rèn)為0.75
    public LinkedHashSet(int initialCapacity) {
        super(initialCapacity, .75f, true);
    }

    // 使用默認(rèn)容量16, 默認(rèn)裝載因子0.75
    public LinkedHashSet() {
        super(16, .75f, true);
    }

    // 將集合c中的所有元素添加到LinkedHashSet中
    // 好奇怪, 這里計(jì)算容量的方式又變了
    // HashSet中使用的是Math.max((int) (c.size()/.75f) + 1, 16)
    // 這一點(diǎn)有點(diǎn)不得其解, 是作者偷懶?
    public LinkedHashSet(Collection c) {
        super(Math.max(2*c.size(), 11), .75f, true);
        addAll(c);
    }

    // 可分割的迭代器, 主要用于多線程并行迭代處理時(shí)使用
    @Override
    public Spliterator spliterator() {
        return Spliterators.spliterator(this, Spliterator.DISTINCT | Spliterator.ORDERED);
    }
}

完了,結(jié)束了,就這么多,這是全部源碼了,真的。

可以看到,LinkedHashSet中一共提供了5個(gè)方法,其中4個(gè)是構(gòu)造方法,還有一個(gè)是迭代器。

4個(gè)構(gòu)造方法都是調(diào)用父類的super(initialCapacity, loadFactor, true);這個(gè)方法。

這個(gè)方法長(zhǎng)什么樣呢?

還記得我們上一節(jié)說(shuō)過(guò)一個(gè)不是public的構(gòu)造方法嗎?就是它。

// HashSet的構(gòu)造方法
    HashSet(int initialCapacity, float loadFactor, boolean dummy) {
        map = new LinkedHashMap<>(initialCapacity, loadFactor);
    }

如上所示,這個(gè)構(gòu)造方法里面使用了LinkedHashMap來(lái)初始化HashSet中的map。

現(xiàn)在這個(gè)邏輯應(yīng)該很清晰了,LinkedHashSet繼承自HashSet,它的添加、刪除、查詢等方法都是直接用的HashSet的,唯一的不同就是它使用LinkedHashMap存儲(chǔ)元素。

那么,開(kāi)篇那幾個(gè)問(wèn)題是否能回答了呢?

總結(jié)

(1)LinkedHashSet的底層使用LinkedHashMap存儲(chǔ)元素。

(2)LinkedHashSet是有序的,它是按照插入的順序排序的。

彩蛋

通過(guò)上面的學(xué)習(xí),我們知道LinkedHashSet底層使用LinkedHashMap存儲(chǔ)元素,而LinkedHashMap是支持按元素訪問(wèn)順序遍歷元素的,也就是可以用來(lái)實(shí)現(xiàn)LRU的,還記得嗎?傳送門(mén)【死磕 java集合之LinkedHashMap源碼分析】

那么,LinkedHashSet支持按元素訪問(wèn)順序排序嗎?

讓我們一起來(lái)分析下。

首先,LinkedHashSet所有的構(gòu)造方法都是調(diào)用HashSet的同一個(gè)構(gòu)造方法,如下:

// HashSet的構(gòu)造方法
    HashSet(int initialCapacity, float loadFactor, boolean dummy) {
        map = new LinkedHashMap<>(initialCapacity, loadFactor);
    }

然后,通過(guò)調(diào)用LinkedHashMap的構(gòu)造方法初始化map,如下所示:

public LinkedHashMap(int initialCapacity, float loadFactor) {
        super(initialCapacity, loadFactor);
        accessOrder = false;
    }

可以看到,這里把a(bǔ)ccessOrder寫(xiě)死為false了。

所以,LinkedHashSet是不支持按訪問(wèn)順序?qū)υ嘏判虻?,只能按插入順序排序?/p>


歡迎關(guān)注我的公眾號(hào)“彤哥讀源碼”,查看更多源碼系列文章, 與彤哥一起暢游源碼的海洋。

死磕 java集合之LinkedHashSet源碼分析

創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國(guó)云服務(wù)器,動(dòng)態(tài)BGP最優(yōu)骨干路由自動(dòng)選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡(luò)助力業(yè)務(wù)部署。公司持有工信部辦法的idc、isp許可證, 機(jī)房獨(dú)有T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確進(jìn)行流量調(diào)度,確保服務(wù)器高可用性。佳節(jié)活動(dòng)現(xiàn)已開(kāi)啟,新人活動(dòng)云服務(wù)器買(mǎi)多久送多久。


文章名稱:死磕java集合之LinkedHashSet源碼分析-創(chuàng)新互聯(lián)
文章起源:http://weahome.cn/article/gjppd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部