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

目錄
哈希計算與數(shù)組索引
哈希沖突的解決方式
擴容機制:負載因子與 rehashing
初始容量設(shè)置的小技巧
首頁 Java java教程 Java Hashmap在內(nèi)部如何工作?

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

Jul 06, 2025 am 12:22 AM

HashMap通過哈希算法將鍵映射為數(shù)組索引實現(xiàn)快速存取,1.先調(diào)用hashCode()獲取哈希值,再通過擾動函數(shù)處理并取模確定索引位置;2.使用鏈表解決哈希沖突,Java 8后鏈表過長會轉(zhuǎn)為紅黑樹以提升查找效率;3.擴容時負載因子默認0.75,超過閾值則rehashing擴大數(shù)組容量;4.可預設(shè)初始容量以減少擴容次數(shù)提升性能。

How Does Java HashMap Work Internally?

Java 的 HashMap 是一個非常常用的集合類,內(nèi)部實現(xiàn)其實挺巧妙的。它通過哈希算法把鍵(Key)映射成數(shù)組索引,從而實現(xiàn)快速的插入和查找。但具體是怎么做到的?我們來拆解幾個關(guān)鍵點。

How Does Java HashMap Work Internally?

哈希計算與數(shù)組索引

HashMap 內(nèi)部使用一個數(shù)組來存儲數(shù)據(jù),每個元素是一個 Node(或者叫 Entry)。當你放入一個鍵值對時,HashMap 會先調(diào)用 key 的 hashCode() 方法獲取一個整數(shù)哈希值,然后通過一個“擾動函數(shù)”再次處理這個哈希值,最后通過取模運算確定在數(shù)組中的位置(也就是 index)。

How Does Java HashMap Work Internally?

舉個例子:
假設(shè)數(shù)組長度是 16,某個 key 的 hash 值經(jīng)過處理后是 35,那 index 就是 35 % 16 = 3,所以這個節(jié)點會被放在數(shù)組下標為 3 的位置。

需要注意的是:

How Does Java HashMap Work Internally?
  • 如果兩個不同的 key 計算出相同的 index,就會發(fā)生哈希碰撞
  • Java 8 中引入了紅黑樹優(yōu)化頻繁碰撞的情況(后面會講)

哈希沖突的解決方式

HashMap 使用鏈表法來處理哈希沖突。也就是說,當多個 key 被映射到同一個數(shù)組下標時,它們會被串在一個鏈表中。

比如你有三個 key-value 對,都落在 index=5 的位置上,那它們會在數(shù)組的第 5 個位置形成一個鏈表。每次查找的時候,需要遍歷這個鏈表進行 key 的比較(equals)。

從 Java 8 開始,如果鏈表長度超過閾值(默認是 8),鏈表會轉(zhuǎn)換為紅黑樹,這樣可以將查找的時間復雜度從 O(n) 降低到 O(log n),提升性能。

不過要注意:

  • 紅黑樹的轉(zhuǎn)換是有代價的,只有在頻繁發(fā)生沖突時才劃算
  • 當樹中元素減少到 6 個以下時,又會退化回鏈表

擴容機制:負載因子與 rehashing

HashMap 不是固定大小的,它會根據(jù)數(shù)據(jù)量自動擴容。決定是否擴容的關(guān)鍵因素是負載因子(load factor),默認是 0.75。

舉個實際的例子:
如果你初始化了一個 HashMap,默認容量是 16,那么當 put 進第 16 * 0.75 = 12 個元素時,HashMap 會擴容為原來的兩倍(變成 32),并重新計算所有 key 的 index,這個過程叫做 rehashing。

擴容雖然能避免過多的哈希沖突,但也有成本:

  • 需要新建一個更大的數(shù)組
  • 把舊數(shù)據(jù)全部重新 hash 并插入新數(shù)組
  • 多線程下還可能引發(fā)死循環(huán)(HashMap 不是線程安全的)

初始容量設(shè)置的小技巧

如果你提前知道大概要放多少個元素,建議構(gòu)造 HashMap 時指定初始容量。這樣可以減少擴容次數(shù),提高性能。

比如你要放 100 個元素,默認負載因子是 0.75,那至少需要 100 / 0.75 ≈ 134 的容量。為了避免多次擴容,可以直接這樣創(chuàng)建:

Map<String, String> map = new HashMap<>(134);

當然,也可以稍微留點余地,設(shè)成 150 或者 200 都沒問題。


基本上就這些。HashMap 的設(shè)計很聰明,但也有一些小細節(jié)容易被忽略,比如 hash 的二次擾動、鏈表轉(zhuǎn)紅黑樹的閾值、擴容時機等等。理解這些,對寫出更高效的代碼還是很有幫助的。

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

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻,版權(quán)歸原作者所有,本站不承擔相應(yīng)法律責任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機

Video Face Swap

Video Face Swap

使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級代碼編輯軟件(SublimeText3)

hashmap和hashtable之間的區(qū)別? hashmap和hashtable之間的區(qū)別? Jun 24, 2025 pm 09:41 PM

HashMap與Hashtable的區(qū)別主要體現(xiàn)在線程安全、null值支持及性能方面。1.線程安全方面,Hashtable是線程安全的,其方法大多為同步方法,而HashMap不做同步處理,非線程安全;2.null值支持上,HashMap允許一個null鍵和多個null值,Hashtable則不允許null鍵或值,否則拋出NullPointerException;3.性能方面,HashMap因無同步機制效率更高,Hashtable因每次操作加鎖性能較低,推薦使用ConcurrentHashMap替

什么是接口中的靜態(tài)方法? 什么是接口中的靜態(tài)方法? Jun 24, 2025 pm 10:57 PM

StaticmethodsininterfaceswereintroducedinJava8toallowutilityfunctionswithintheinterfaceitself.BeforeJava8,suchfunctionsrequiredseparatehelperclasses,leadingtodisorganizedcode.Now,staticmethodsprovidethreekeybenefits:1)theyenableutilitymethodsdirectly

JIT編譯器如何優(yōu)化代碼? JIT編譯器如何優(yōu)化代碼? Jun 24, 2025 pm 10:45 PM

JIT編譯器通過方法內(nèi)聯(lián)、熱點檢測與編譯、類型推測與去虛擬化、冗余操作消除四種方式優(yōu)化代碼。1.方法內(nèi)聯(lián)減少調(diào)用開銷,將頻繁調(diào)用的小方法直接插入調(diào)用處;2.熱點檢測識別高頻執(zhí)行代碼并集中優(yōu)化,節(jié)省資源;3.類型推測收集運行時類型信息實現(xiàn)去虛擬化調(diào)用,提升效率;4.冗余操作消除根據(jù)運行數(shù)據(jù)刪除無用計算和檢查,增強性能。

什么是實例初始器塊? 什么是實例初始器塊? Jun 25, 2025 pm 12:21 PM

實例初始化塊在Java中用于在創(chuàng)建對象時運行初始化邏輯,其執(zhí)行先于構(gòu)造函數(shù)。它適用于多個構(gòu)造函數(shù)共享初始化代碼、復雜字段初始化或匿名類初始化場景,與靜態(tài)初始化塊不同的是它每次實例化時都會執(zhí)行,而靜態(tài)初始化塊僅在類加載時運行一次。

什么是工廠模式? 什么是工廠模式? Jun 24, 2025 pm 11:29 PM

工廠模式用于封裝對象創(chuàng)建邏輯,使代碼更靈活、易維護、松耦合。其核心答案是:通過集中管理對象創(chuàng)建邏輯,隱藏實現(xiàn)細節(jié),支持多種相關(guān)對象的創(chuàng)建。具體描述如下:工廠模式將對象創(chuàng)建交給專門的工廠類或方法處理,避免直接使用newClass();適用于多類型相關(guān)對象創(chuàng)建、創(chuàng)建邏輯可能變化、需隱藏實現(xiàn)細節(jié)的場景;例如支付處理器中通過工廠統(tǒng)一創(chuàng)建Stripe、PayPal等實例;其實現(xiàn)包括工廠類根據(jù)輸入?yún)?shù)決定返回的對象,所有對象實現(xiàn)共同接口;常見變體有簡單工廠、工廠方法和抽象工廠,分別適用于不同復雜度的需求。

變量的最終關(guān)鍵字是什么? 變量的最終關(guān)鍵字是什么? Jun 24, 2025 pm 07:29 PM

InJava,thefinalkeywordpreventsavariable’svaluefrombeingchangedafterassignment,butitsbehaviordiffersforprimitivesandobjectreferences.Forprimitivevariables,finalmakesthevalueconstant,asinfinalintMAX_SPEED=100;wherereassignmentcausesanerror.Forobjectref

什么是同步? 什么是同步? Jun 24, 2025 pm 08:21 PM

Synchronizationistheprocessofcoordinatingtwoormorethingstostayaligned,whetherdigitalorphysical.Intechnology,itensuresdataconsistencyacrossdevicesthroughcloudserviceslikeGoogleDriveandiCloud,keepingcontacts,calendarevents,andbookmarksupdated.Outsidete

什么是類型鑄造? 什么是類型鑄造? Jun 24, 2025 pm 11:09 PM

類型轉(zhuǎn)換有兩種:隱式和顯式。1.隱式轉(zhuǎn)換自動發(fā)生,如將int轉(zhuǎn)為double;2.顯式轉(zhuǎn)換需手動操作,如使用(int)myDouble。需要類型轉(zhuǎn)換的情況包括處理用戶輸入、數(shù)學運算或函數(shù)間傳遞不同類型的值時。需要注意的問題有:浮點數(shù)轉(zhuǎn)整數(shù)會截斷小數(shù)部分、大類型轉(zhuǎn)小類型可能導致數(shù)據(jù)丟失、某些語言不允許直接轉(zhuǎn)換特定類型。正確理解語言的轉(zhuǎn)換規(guī)則有助于避免錯誤。

See all articles