欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中的LinkedHashSet源碼解讀

 更新時(shí)間:2023年09月04日 09:48:36   作者:伊顰伊笑  
這篇文章主要介紹了Java中的LinkedHashSet源碼解讀,LinkedHashSet?是?Java?中的一個(gè)集合類,它是?HashSet?的子類,并實(shí)現(xiàn)了?Set?接口,與?HashSet?不同的是,LinkedHashSet?保留了元素插入的順序,并且具有?HashSet?的快速查找特性,需要的朋友可以參考下

LinkedHashSet

在這里插入圖片描述

基本介紹

  1. LinkedHashSet 是 HashSet 的子類
  2. LinkedHashSet 底層是一個(gè) LinkedHashMap,底層維護(hù)了一個(gè)數(shù)組+雙向鏈表
  3. LinkedHashSet 根據(jù)元素的 hashCode 值來(lái)決定元素的存儲(chǔ)位置,同時(shí)使用鏈表維護(hù)元素的次序(圖),這使得元素看起來(lái)是以插入順序保存的。
  4. LinkedHashSet 不允許添重復(fù)元素

說(shuō)明

在這里插入圖片描述

  • 在 LinkedHastSet 中維護(hù)了一個(gè) hash 表和雙向鏈表(LinkedHashSet 有head和tail)
  • 每一個(gè)節(jié)點(diǎn)有 pre 和 next 屬性,這樣可以形成雙向鏈表
  • 在添加一個(gè)元素時(shí),先求hash值,再求索引,確定該元素在hashtable 的位置,然后將添加的元素加入到雙向鏈表(如果已經(jīng)存在,不添加【原則和 hashset 一樣】)
tail.next = newElement//簡(jiǎn)單指定
newElement.pre = tail
tail = newEelment;
  • 這樣的話,我們遍歷 LinkedHashSet 也能確保插入順序和遍歷順序一致

LinkedHashSet 源碼解讀

package collection_;
import java.util.LinkedHashSet;
import java.util.Set;
/**
 * @Author: Gin
 * @Description:
 * @Modified By: Gin
 * @Date: Created in 11:12 2021/9/22
 */
public class LinkedHashSetSource {
    public static void main(String[] args) {
        // 分析 LinkedHashSet 的底層機(jī)制
        Set set = new LinkedHashSet();
        set.add(new String("AAA"));
        set.add(456);
        set.add(456);
        set.add(new Customer("Tom", 1));
        set.add(123);
        set.add("Gin");
        System.out.println("set = " + set);
        // 解讀:
        // 1. LinkedHashSet 中元素的取出順序和加入順序一致
        // 2. LinkedHashSet(HashSet的子類) 底層其實(shí)是 LinkedHashMap(HashMap的子類)
        // 3. LinkedHashSet 底層結(jié)構(gòu)(table數(shù)組 + 雙向鏈表)
        // 4. 第一次添加數(shù)據(jù),將 table數(shù)組 直接擴(kuò)容至 16 個(gè)空間大小
        // 5. table數(shù)組的類型為 HashMap$Node[]
        // 6. table數(shù)組中存放數(shù)據(jù)的結(jié)點(diǎn)類型是 LinkedHashMap$Entry
        /*
            LinkedHashMap 的靜態(tài)內(nèi)部類 Entry 繼承自 HashMap 的靜態(tài)內(nèi)部類 Node
            static class Entry<K,V> extends HashMap.Node<K,V> {
                Entry<K,V> before, after; // before, after 用來(lái)形成雙向鏈表
                Entry(int hash, K key, V value, Node<K,V> next) {
                    super(hash, key, value, next);
                }
            }
         */
    }
}
class Customer{
    private String name;
    private int no;
    public Customer(String name, int no) {
        this.name = name;
        this.no = no;
    }
}

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述

到此這篇關(guān)于Java中的LinkedHashSet源碼解讀的文章就介紹到這了,更多相關(guān)LinkedHashSet源碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • centos上安裝配置java WEB環(huán)境

    centos上安裝配置java WEB環(huán)境

    前提是centos6.3系統(tǒng)已經(jīng)安裝好,在這里以64位系統(tǒng)為例,下面是jdk,tomcat,mysql下載安裝步驟,有需要的小伙伴可以參考下
    2016-10-10
  • Java Comparator比較器實(shí)例解析

    Java Comparator比較器實(shí)例解析

    這篇文章主要介紹了Java Comparator比較器實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • 詳解如何使用XML配置來(lái)定義和管理Spring Bean

    詳解如何使用XML配置來(lái)定義和管理Spring Bean

    XML 配置文件是 Spring 中傳統(tǒng)的 Bean 配置方式,通過(guò)定義 XML 元素來(lái)描述 Bean 及其依賴關(guān)系,在 Spring 框架中,Bean 是由 Spring IoC(控制反轉(zhuǎn))容器管理的對(duì)象,本文將詳細(xì)介紹如何使用 XML 配置來(lái)定義和管理 Spring Bean,需要的朋友可以參考下
    2024-06-06
  • Mybatis逆向工程實(shí)現(xiàn)連接MySQL數(shù)據(jù)庫(kù)

    Mybatis逆向工程實(shí)現(xiàn)連接MySQL數(shù)據(jù)庫(kù)

    本文主要介紹了Mybatis逆向工程實(shí)現(xiàn)連接MySQL數(shù)據(jù)庫(kù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • springboot中不能獲取post請(qǐng)求參數(shù)的解決方法

    springboot中不能獲取post請(qǐng)求參數(shù)的解決方法

    這篇文章主要介紹了springboot中不能獲取post請(qǐng)求參數(shù)的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • Java中的Pair詳細(xì)

    Java中的Pair詳細(xì)

    這篇文章主要介紹Java中的很有意思的Pair,下面文章會(huì)以Pair用法展開(kāi),感興趣的小伙伴可以參考下面文章的具體內(nèi)容
    2021-10-10
  • SpringBoot整合H2數(shù)據(jù)庫(kù)的操作方法

    SpringBoot整合H2數(shù)據(jù)庫(kù)的操作方法

    H2是一個(gè)Java語(yǔ)言編寫(xiě)的嵌入式數(shù)據(jù)庫(kù),它不受平臺(tái)的限制,同時(shí)H2提供了一個(gè)十分方便的web控制臺(tái),用于操作和管理數(shù)據(jù)庫(kù)內(nèi)容,本文介紹SpringBoot整合H2數(shù)據(jù)庫(kù)的方法,感興趣的朋友一起看看吧
    2024-01-01
  • springboot掃碼登錄的簡(jiǎn)單實(shí)現(xiàn)

    springboot掃碼登錄的簡(jiǎn)單實(shí)現(xiàn)

    本文主要介紹基于SpringBoot + Vue + Android實(shí)現(xiàn)的掃碼登錄,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Java枚舉學(xué)習(xí)之定義和基本特性詳解

    Java枚舉學(xué)習(xí)之定義和基本特性詳解

    枚舉是JAVA?5.0后增加的一個(gè)重要類型??梢杂脕?lái)表示一組取值范圍固定的變量。本文將通過(guò)示例為大家詳細(xì)講解枚舉的定義和基本特性,感興趣的可以了解一下
    2022-08-08
  • Spring boot集成spring session實(shí)現(xiàn)session共享的方法

    Spring boot集成spring session實(shí)現(xiàn)session共享的方法

    這篇文章主要介紹了Spring boot集成spring session實(shí)現(xiàn)session共享的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-06-06

最新評(píng)論