溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

JDK7 HashMap環(huán)的產(chǎn)生原理是怎樣的

發(fā)布時(shí)間:2021-12-03 18:32:35 來源:億速云 閱讀:131 作者:柒染 欄目:大數(shù)據(jù)

JDK7 HashMap環(huán)的產(chǎn)生原理是怎樣的,針對這個(gè)問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡單易行的方法。

JDK7中當(dāng)我們用頭插法 對舊table數(shù)據(jù)重定位到新table的時(shí)候我們知道是會行程環(huán)的,環(huán)產(chǎn)生的核心函數(shù)transfer如下,其中重點(diǎn)關(guān)注部分以標(biāo)出。
JDK7 HashMap環(huán)的產(chǎn)生原理是怎樣的

  1. 頭插法正常情況下:
    JDK7 HashMap環(huán)的產(chǎn)生原理是怎樣的

  2. 并發(fā)情況下,比如我有兩個(gè)線程在同時(shí)進(jìn)行put數(shù)據(jù)跟擴(kuò)容操作,線程1只執(zhí)行了Entry<K,V> next = e.next就被掛起了,而線程2正常執(zhí)行完畢,結(jié)果圖如下:
    JDK7 HashMap環(huán)的產(chǎn)生原理是怎樣的
    線程2執(zhí)行完畢后線程1接著從原來的暫停處開始執(zhí)行下面的語句:
    JDK7 HashMap環(huán)的產(chǎn)生原理是怎樣的
    通過逐步分析跟繪圖可以知道紅色部分會有環(huán)產(chǎn)生。JDK中HashMap是不安全的,多線程情況下要用ConcurrentHashMap。

7vs8

  1. 7中找Hash用了4次,8中只用了1次。

  2. 7 = 數(shù)組 + 鏈表,8 = 數(shù)組 + 鏈表 + 紅黑樹

  3. 7中是頭插法,多線程容易造成環(huán),8中是尾插法。

  4. 7的擴(kuò)容是全部數(shù)據(jù)重新定位,8中是位置不變+ 移動舊size大小來實(shí)現(xiàn)更好些。

  5. 7是先判斷是否要擴(kuò)容再插入,8中是先插入再看是否要擴(kuò)容。

  6. HashMap不管78都是現(xiàn)場不安全的,多線程情況下記得用ConcurrentHashmapConcurrentHashmap下篇文章說。

常見問題

隨機(jī)搜羅了一些常見HashMap問題,如果把上述代碼都看懂了應(yīng)付這些應(yīng)該沒問題。

  1. HashMap原理,內(nèi)部數(shù)據(jù)結(jié)構(gòu)。

  2. HashMap中的put,get,remove大致過程。

  3. HashMap中 hash函數(shù)實(shí)現(xiàn)。

  4. HashMap如何擴(kuò)容。

  5. HashMap幾個(gè)重要參數(shù)為什么這樣設(shè)定。

  6. HashMap為什么線程不安全,如何替換。

  7. HashMap在JDK7跟JDK8中的區(qū)別。

  8. HashMap中鏈表跟紅黑樹切換思路。

關(guān)于JDK7 HashMap環(huán)的產(chǎn)生原理是怎樣的問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI