您好,登錄后才能下訂單哦!
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)出。
頭插法正常情況下:
并發(fā)情況下,比如我有兩個(gè)線程在同時(shí)進(jìn)行put數(shù)據(jù)跟擴(kuò)容操作,線程1只執(zhí)行了Entry<K,V> next = e.next
就被掛起了,而線程2正常執(zhí)行完畢,結(jié)果圖如下:
線程2執(zhí)行完畢后線程1接著從原來的暫停處開始執(zhí)行下面的語句:
通過逐步分析跟繪圖可以知道紅色部分會有環(huán)產(chǎn)生。JDK中HashMap是不安全的,多線程情況下要用ConcurrentHashMap。
7中找
Hash
用了4次,8中只用了1次。7 = 數(shù)組 + 鏈表,8 = 數(shù)組 + 鏈表 + 紅黑樹
7中是頭插法,多線程容易造成環(huán),8中是尾插法。
7的擴(kuò)容是全部數(shù)據(jù)重新定位,8中是位置不變+ 移動舊size大小來實(shí)現(xiàn)更好些。
7是先判斷是否要擴(kuò)容再插入,8中是先插入再看是否要擴(kuò)容。
HashMap
不管78都是現(xiàn)場不安全的,多線程情況下記得用ConcurrentHashmap
。ConcurrentHashmap
下篇文章說。
隨機(jī)搜羅了一些常見HashMap
問題,如果把上述代碼都看懂了應(yīng)付這些應(yīng)該沒問題。
HashMap原理,內(nèi)部數(shù)據(jù)結(jié)構(gòu)。
HashMap中的put,get,remove大致過程。
HashMap中 hash函數(shù)實(shí)現(xiàn)。
HashMap如何擴(kuò)容。
HashMap幾個(gè)重要參數(shù)為什么這樣設(shè)定。
HashMap為什么線程不安全,如何替換。
HashMap在JDK7跟JDK8中的區(qū)別。
HashMap中鏈表跟紅黑樹切換思路。
關(guān)于JDK7 HashMap環(huán)的產(chǎn)生原理是怎樣的問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識。
免責(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)容。