国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
Hash 算法與索引計(jì)算
處理哈希衝突:鍊錶與紅黑樹(shù)
擴(kuò)容機(jī)制:resize()
關(guān)於key 的要求
總結(jié)一下
首頁(yè) Java java教程 Hashmap在Java內(nèi)部如何工作?

Hashmap在Java內(nèi)部如何工作?

Jul 16, 2025 am 02:41 AM
java hashmap

HashMap 在Java 中的底層實(shí)現(xiàn)是數(shù)組、鍊錶和紅黑樹(shù)的組合結(jié)構(gòu)。 1. 它通過(guò)key 的hash 值計(jì)算索引位置,使用擾動(dòng)處理減少哈希碰撞;2. 當(dāng)發(fā)生哈希衝突時(shí),採(cǎi)用鍊錶存儲(chǔ)相同索引的元素;3. 鍊錶長(zhǎng)度超過(guò)閾值(默認(rèn)8)時(shí)轉(zhuǎn)換為紅黑樹(shù)以提升性能;4. 元素?cái)?shù)量超過(guò)容量乘以負(fù)載因子(默認(rèn)0.75)時(shí)觸發(fā)擴(kuò)容,將數(shù)組大小翻倍並重新分佈元素;5. 自定義key 時(shí)需重寫equals() 和hashCode() 方法以確保正確存取。

How does HashMap work internally in Java?

HashMap 在Java 中的底層實(shí)現(xiàn)主要依賴於數(shù)組和鍊錶(或紅黑樹(shù))結(jié)構(gòu)。當(dāng)你把鍵值對(duì)放入HashMap 時(shí),它會(huì)根據(jù)key 的hash 值決定該數(shù)據(jù)存儲(chǔ)的位置。如果不同key 計(jì)算出的索引相同,就會(huì)發(fā)生哈希衝突,這時(shí)候HashMap 會(huì)使用鍊錶或紅黑樹(shù)來(lái)處理這些衝突。

How does HashMap work internally in Java?

Hash 算法與索引計(jì)算

每個(gè)對(duì)像都有自己的hashCode()方法,HashMap 並不會(huì)直接使用這個(gè)值,而是對(duì)其進(jìn)行一次“擾動(dòng)”處理,也就是再哈希(rehash)。這樣做的目的是為了減少哈希碰撞的概率。

How does HashMap work internally in Java?
 static final int hash(Object key) {
    int h;
    return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);
}

之後,HashMap 會(huì)用這個(gè)hash 值和數(shù)組長(zhǎng)度進(jìn)行按位與操作,得到一個(gè)索引值:

 index = (n - 1) & hash;

這裡n 是數(shù)組的長(zhǎng)度,必須是2 的冪次,這樣能保證分佈更均勻,減少碰撞。

How does HashMap work internally in Java?

處理哈希衝突:鍊錶與紅黑樹(shù)

當(dāng)多個(gè)不同的key 被映射到同一個(gè)數(shù)組位置時(shí),它們會(huì)被組織成一個(gè)鍊錶。但鍊錶過(guò)長(zhǎng)會(huì)影響查找效率,因此在鍊錶長(zhǎng)度超過(guò)一定閾值(默認(rèn)是8)後,鍊錶會(huì)被轉(zhuǎn)換為紅黑樹(shù),以提高查找、插入和刪除的性能。

  • 當(dāng)節(jié)點(diǎn)數(shù)小於6 時(shí),紅黑樹(shù)又會(huì)退化回鍊錶
  • 這個(gè)設(shè)計(jì)是為了平衡查找效率和空間開(kāi)銷

所以你可以理解為:HashMap = 數(shù)組鍊錶紅黑樹(shù)


擴(kuò)容機(jī)制:resize()

當(dāng)HashMap 中的元素?cái)?shù)量超過(guò)容量乘以負(fù)載因子(默認(rèn)是0.75)時(shí),HashMap 會(huì)進(jìn)行擴(kuò)容。擴(kuò)容過(guò)程包括:

  • 創(chuàng)建一個(gè)新的數(shù)組,大小是原來(lái)的兩倍
  • 把舊數(shù)組中的所有元素重新計(jì)算hash 和index,複製到新數(shù)組中

這個(gè)過(guò)程是比較耗時(shí)的,所以在初始化HashMap 時(shí),如果能預(yù)估數(shù)據(jù)量,最好指定初始容量,避免頻繁擴(kuò)容。


關(guān)於key 的要求

HashMap 允許key 為null,這種key 會(huì)被放在數(shù)組的第一個(gè)位置。但如果你自定義了key 的類型,比如一個(gè)類,那麼一定要注意重寫equals()hashCode()方法,否則可能導(dǎo)致無(wú)法正確獲取值或者內(nèi)存洩漏。

例如:

 class Person {
    String name;

    @Override
    public int hashCode() {
        return name.hashCode();
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj) return true;
        if (!(obj instanceof Person)) return false;
        return this.name.equals(((Person) obj).name);
    }
}

總結(jié)一下

HashMap 內(nèi)部其實(shí)就是一個(gè)動(dòng)態(tài)數(shù)組,加上鍊表或紅黑樹(shù)的組合結(jié)構(gòu)。它的高效來(lái)自於良好的哈希算法、合理的衝突處理策略以及自動(dòng)擴(kuò)容機(jī)制。理解這些原理有助於寫出更高效的代碼,也能幫助你在面試或調(diào)試中更好地應(yīng)對(duì)相關(guān)問(wèn)題。

基本上就這些。

以上是Hashmap在Java內(nèi)部如何工作?的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1600
29
PHP教程
1502
276
如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

要正確處理JDBC事務(wù),必須先關(guān)閉自動(dòng)提交模式,再執(zhí)行多個(gè)操作,最後根據(jù)結(jié)果提交或回滾;1.調(diào)用conn.setAutoCommit(false)以開(kāi)始事務(wù);2.執(zhí)行多個(gè)SQL操作,如INSERT和UPDATE;3.若所有操作成功則調(diào)用conn.commit(),若發(fā)生異常則調(diào)用conn.rollback()確保數(shù)據(jù)一致性;同時(shí)應(yīng)使用try-with-resources管理資源,妥善處理異常並關(guān)閉連接,避免連接洩漏;此外建議使用連接池、設(shè)置保存點(diǎn)實(shí)現(xiàn)部分回滾,並保持事務(wù)盡可能短以提升性能。

了解Java虛擬機(jī)(JVM)內(nèi)部 了解Java虛擬機(jī)(JVM)內(nèi)部 Aug 01, 2025 am 06:31 AM

TheJVMenablesJava’s"writeonce,runanywhere"capabilitybyexecutingbytecodethroughfourmaincomponents:1.TheClassLoaderSubsystemloads,links,andinitializes.classfilesusingbootstrap,extension,andapplicationclassloaders,ensuringsecureandlazyclassloa

如何使用Java的日曆? 如何使用Java的日曆? Aug 02, 2025 am 02:38 AM

使用java.time包中的類替代舊的Date和Calendar類;2.通過(guò)LocalDate、LocalDateTime和LocalTime獲取當(dāng)前日期時(shí)間;3.使用of()方法創(chuàng)建特定日期時(shí)間;4.利用plus/minus方法不可變地增減時(shí)間;5.使用ZonedDateTime和ZoneId處理時(shí)區(qū);6.通過(guò)DateTimeFormatter格式化和解析日期字符串;7.必要時(shí)通過(guò)Instant與舊日期類型兼容;現(xiàn)代Java中日期處理應(yīng)優(yōu)先使用java.timeAPI,它提供了清晰、不可變且線

比較Java框架:Spring Boot vs Quarkus vs Micronaut 比較Java框架:Spring Boot vs Quarkus vs Micronaut Aug 04, 2025 pm 12:48 PM

前形式攝取,quarkusandmicronautleaddueTocile timeProcessingandGraalvSupport,withquarkusoftenpernperforminglightbetterine nosserless notelless centarios.2。

垃圾收集如何在Java工作? 垃圾收集如何在Java工作? Aug 02, 2025 pm 01:55 PM

Java的垃圾回收(GC)是自動(dòng)管理內(nèi)存的機(jī)制,通過(guò)回收不可達(dá)對(duì)象釋放堆內(nèi)存,減少內(nèi)存洩漏風(fēng)險(xiǎn)。 1.GC從根對(duì)象(如棧變量、活動(dòng)線程、靜態(tài)字段等)出發(fā)判斷對(duì)象可達(dá)性,無(wú)法到達(dá)的對(duì)像被標(biāo)記為垃圾。 2.基於標(biāo)記-清除算法,標(biāo)記所有可達(dá)對(duì)象,清除未標(biāo)記對(duì)象。 3.採(cǎi)用分代收集策略:新生代(Eden、S0、S1)頻繁執(zhí)行MinorGC;老年代執(zhí)行較少但耗時(shí)較長(zhǎng)的MajorGC;Metaspace存儲(chǔ)類元數(shù)據(jù)。 4.JVM提供多種GC器:SerialGC適用於小型應(yīng)用;ParallelGC提升吞吐量;CMS降

了解網(wǎng)絡(luò)端口和防火牆 了解網(wǎng)絡(luò)端口和防火牆 Aug 01, 2025 am 06:40 AM

NetworkPortSandFireWallsworkTogetHertoEnableCommunication whereSeringSecurity.1.NetWorkPortSareVirtualendPointSnumbered0-655 35,with-Well-with-Newonportslike80(HTTP),443(https),22(SSH)和25(smtp)sindiessingspefificservices.2.portsoperateervertcp(可靠,c

以身作則,解釋說(shuō)明 以身作則,解釋說(shuō)明 Aug 02, 2025 am 06:26 AM

defer用於在函數(shù)返回前執(zhí)行指定操作,如清理資源;參數(shù)在defer時(shí)立即求值,函數(shù)按後進(jìn)先出(LIFO)順序執(zhí)行;1.多個(gè)defer按聲明逆序執(zhí)行;2.常用於文件關(guān)閉等安全清理;3.可修改命名返回值;4.即使發(fā)生panic也會(huì)執(zhí)行,適合用於recover;5.避免在循環(huán)中濫用defer,防止資源洩漏;正確使用可提升代碼安全性和可讀性。

Java並發(fā)公用事業(yè):執(zhí)行人員服務(wù)和叉/加入 Java並發(fā)公用事業(yè):執(zhí)行人員服務(wù)和叉/加入 Aug 03, 2025 am 01:54 AM

ExecutorService適用於獨(dú)立任務(wù)的異步執(zhí)行,如I/O操作或定時(shí)任務(wù),使用線程池管理並發(fā),通過(guò)submit提交Runnable或Callable任務(wù),並用Future獲取結(jié)果,需注意無(wú)界隊(duì)列風(fēng)險(xiǎn)和顯式關(guān)閉線程池;2.Fork/Join框架專為可拆分的CPU密集型任務(wù)設(shè)計(jì),基於分治法和工作竊取算法,通過(guò)RecursiveTask或RecursiveAction實(shí)現(xiàn)任務(wù)遞歸拆分,由ForkJoinPool調(diào)度執(zhí)行,適合大數(shù)組求和、排序等場(chǎng)景,需合理設(shè)置拆分閾值避免開(kāi)銷;3.選擇依據(jù):獨(dú)立任

See all articles