老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

死磕java集合之LinkedHashSet源碼分析-創新互聯

問題

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

站在用戶的角度思考問題,與客戶深入溝通,找到泌陽網站設計與泌陽網站推廣的解決方案,憑借多年的經驗,讓設計與互聯網技術結合,創造個性化、用戶體驗好的作品,建站類型包括:網站設計制作、成都網站設計、企業官網、英文網站、手機端網站、網站推廣、域名注冊雅安服務器托管、企業郵箱。業務覆蓋泌陽地區。

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

(3)LinkedHashSet是有序的嗎?

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

簡介

上一節我們說HashSet中的元素是無序的,那么有沒有什么辦法保證Set中的元素是有序的呢?

答案是當然可以。

我們今天的主角LinkedHashSet就有這個功能,它是怎么實現有序的呢?讓我們來一起學習吧。

源碼分析

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

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);
    }

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

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

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

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

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

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

4個構造方法都是調用父類的super(initialCapacity, loadFactor, true);這個方法。

這個方法長什么樣呢?

還記得我們上一節說過一個不是public的構造方法嗎?就是它。

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

如上所示,這個構造方法里面使用了LinkedHashMap來初始化HashSet中的map。

現在這個邏輯應該很清晰了,LinkedHashSet繼承自HashSet,它的添加、刪除、查詢等方法都是直接用的HashSet的,唯一的不同就是它使用LinkedHashMap存儲元素。

那么,開篇那幾個問題是否能回答了呢?

總結

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

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

彩蛋

通過上面的學習,我們知道LinkedHashSet底層使用LinkedHashMap存儲元素,而LinkedHashMap是支持按元素訪問順序遍歷元素的,也就是可以用來實現LRU的,還記得嗎?傳送門【死磕 java集合之LinkedHashMap源碼分析】

那么,LinkedHashSet支持按元素訪問順序排序嗎?

讓我們一起來分析下。

首先,LinkedHashSet所有的構造方法都是調用HashSet的同一個構造方法,如下:

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

然后,通過調用LinkedHashMap的構造方法初始化map,如下所示:

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

可以看到,這里把accessOrder寫死為false了。

所以,LinkedHashSet是不支持按訪問順序對元素排序的,只能按插入順序排序。


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

死磕 java集合之LinkedHashSet源碼分析

創新互聯www.cdcxhl.cn,專業提供香港、美國云服務器,動態BGP最優骨干路由自動選擇,持續穩定高效的網絡助力業務部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統配攻擊溯源,準確進行流量調度,確保服務器高可用性。佳節活動現已開啟,新人活動云服務器買多久送多久。


標題名稱:死磕java集合之LinkedHashSet源碼分析-創新互聯
文章起源:http://www.xueling.net.cn/article/gjppd.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 国产爆乳无码av在线播放 | 国产欧美另类久久久精品91区 | 国产一区在线观看免费 | 国产91艳遇在线观看 | 毛片免费无限看 | 国产97精品一区二区在线观看 | 亚洲成在人线在线播放无码 | 国产精选大秀一区二区 | 免费在线国产精品 | www视频在线免费观看 | 农村妇女一级片 | 亚洲av无码国产精品色午夜洪 | 麻豆一区二区大豆行情 | 欧美国产综合一区二区 | 狠狠躁夜夜躁人人爽天天不 | 久草网免费 | 精品国产三级a在线观看 | 免费观看日韩毛片 | ass年轻少妇bbwpic精品 | 色av综合 | 我要看日本黄色小视频 | 日本污漫| www.嫩草影院 | 国产高清在线观看一区 | JAPANESE日本爆乳巨大 | 91精品免费?看 | 蜜桃av网站 | 成人免费看的A级毛片 | 免费国产自线拍一欧美视频 | 狠狠久久亚洲欧美专区 | 国产亚洲精品第一综合另类灬 | 极品福利在线 | 有码精品| 亚洲成人精| 啊灬啊灬啊灬快灬A片免费 女人喷液全过程在线观看 色婷婷综合和线在线 | 无码成人午夜在线观看 | 男人操女人的视频网站 | 国产强奷在线播放免费不卡 | 催眠教师~淫辱の教室 | 久久国产免费观看精品 | 麻豆传媒在线观看 |