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

JDK1.7中HashMap的死循環(huán)問(wèn)題及解決方案

 更新時(shí)間:2023年10月12日 09:30:18   作者:jacheut  
這篇文章主要為大家介紹了JDK1.7中HashMap的死循環(huán)問(wèn)題及解決方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

hashMap在多線程環(huán)境下的表現(xiàn)

  • 在jdk1.7中多線程put時(shí)可能會(huì)導(dǎo)致get無(wú)限循環(huán),具體表現(xiàn)為CPU使用率100%;

該方法實(shí)現(xiàn)的機(jī)制就是將每個(gè)鏈表轉(zhuǎn)化到新鏈表,并且鏈表中的位置發(fā)生反轉(zhuǎn),而這在多線程情況下是很容易造成鏈表回路,從而發(fā)生 get() 死循環(huán)。所以只要保證建新鏈時(shí)還是按照原來(lái)的順序的話就不會(huì)產(chǎn)生循環(huán)(JDK 8 的改進(jìn))。即在jdk1.7是采用的頭插法,在jdk1.8使用了尾插法解決。

HashMap死循環(huán)只發(fā)生在JDK1.7版本中,主要原因是JDK1.7中的HashMap,在頭插法 加 鏈表 加 多線程并發(fā) 加 擴(kuò)容這幾個(gè)情形累加到一起就會(huì)形成死循環(huán)。多線程環(huán)境下建議采用ConcurrentHashMap替代。

  • 多線程put時(shí)可能導(dǎo)致元素丟失 原因:當(dāng)多個(gè)線程同時(shí)執(zhí)行addEntry(hash,key ,value,i)時(shí),如果產(chǎn)生哈希碰撞,導(dǎo)致兩個(gè)線程得到同樣的bucketIndex去存儲(chǔ),就可能會(huì)發(fā)生元素覆蓋丟失的情況

Hashmap中的鏈表大小超過(guò)八個(gè)時(shí)會(huì)自動(dòng)轉(zhuǎn)化為紅黑樹(shù),當(dāng)刪除小于六時(shí)重新變?yōu)殒湵?,為啥呢?/h2>

根據(jù)泊松分布,在負(fù)載因子默認(rèn)為0.75的時(shí)候,單個(gè)hash槽內(nèi)元素個(gè)數(shù)為8的概率小于百萬(wàn)分之一,所以將7作為一個(gè)分水嶺,等于7的時(shí)候不轉(zhuǎn)換,大于等于8的時(shí)候才進(jìn)行轉(zhuǎn)換,小于等于6的時(shí)候就化為鏈表。 避免樹(shù)和鏈表的頻繁轉(zhuǎn)換

從時(shí)間復(fù)雜度分析,樹(shù)的查詢時(shí)間復(fù)雜度是logn,所于大于等于8使用紅黑樹(shù)。

Collections.synchronizedMap是怎么實(shí)現(xiàn)線程安全的

在SynchronizedMap內(nèi)部維護(hù)了一個(gè)普通對(duì)象Map,還有排斥鎖mutex,如圖

我們?cè)谡{(diào)用這個(gè)方法的時(shí)候就需要傳入一個(gè)Map,可以看到有兩個(gè)構(gòu)造器,如果你傳入了mutex參數(shù),則將對(duì)象排斥鎖賦值為傳入的對(duì)象。

如果沒(méi)有,則將對(duì)象排斥鎖賦值為this,即調(diào)用synchronizedMap的對(duì)象,就是上面的Map。

創(chuàng)建出synchronizedMap之后,再操作map的時(shí)候,就會(huì)對(duì)方法上鎖。

以上就是JDK1.7中HashMap的死循環(huán)問(wèn)題及解決方案的詳細(xì)內(nèi)容,更多關(guān)于JDK1.7 HashMap死循環(huán)解決的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • java 面向?qū)ο竺嬖嚰\

    java 面向?qū)ο竺嬖嚰\

    這篇文章主要介紹了java 面向?qū)ο竺嬖嚰\的相關(guān)資料,這里整理了面向?qū)ο蟮幕A(chǔ)知識(shí),幫助大家學(xué)習(xí)理解此部分的知識(shí),需要的朋友可以參考下
    2016-11-11
  • idea?http?request無(wú)法識(shí)別環(huán)境變量的解決步驟

    idea?http?request無(wú)法識(shí)別環(huán)境變量的解決步驟

    AlibabaCloudToolkit插件安裝后在?Editor->File?Types增加?AlibabaCloudROStemplates(JSON)項(xiàng)且會(huì)配置為解析*.json?文件,導(dǎo)致http?client無(wú)法正確解析http-client.env.json文件而無(wú)法讀取環(huán)境變量,本文介紹idea?http?request無(wú)法識(shí)別環(huán)境變量問(wèn)題,需要的朋友可以參考下
    2023-08-08
  • java實(shí)現(xiàn)百度云文字識(shí)別接口代碼

    java實(shí)現(xiàn)百度云文字識(shí)別接口代碼

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)百度云文字識(shí)別的接口代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • springboot?security使用jwt認(rèn)證方式

    springboot?security使用jwt認(rèn)證方式

    這篇文章主要介紹了springboot?security使用jwt認(rèn)證方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2025-04-04
  • springmvc接收json串,轉(zhuǎn)換為實(shí)體類List方法

    springmvc接收json串,轉(zhuǎn)換為實(shí)體類List方法

    今天小編就為大家分享一篇springmvc接收json串,轉(zhuǎn)換為實(shí)體類List方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • Spring如何正確注入集合類型

    Spring如何正確注入集合類型

    這篇文章主要介紹了Spring如何正確注入集合類型,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-09-09
  • 認(rèn)證授權(quán)中解決AuthenticationManager無(wú)法注入問(wèn)題

    認(rèn)證授權(quán)中解決AuthenticationManager無(wú)法注入問(wèn)題

    這篇文章主要介紹了認(rèn)證授權(quán)中解決AuthenticationManager無(wú)法注入問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-10-10
  • Springboot?application.yml配置文件拆分方式

    Springboot?application.yml配置文件拆分方式

    這篇文章主要介紹了Springboot?application.yml配置文件拆分方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • java日志門面之JCL和SLF4J詳解

    java日志門面之JCL和SLF4J詳解

    這篇文章主要給大家介紹了關(guān)于java日志門面之JCL和SLF4J的相關(guān)資料,在系統(tǒng)開(kāi)發(fā)過(guò)程中日志框架的選擇與更換是一大挑戰(zhàn),日志門面的概念,如JCL和SLF4J,允許開(kāi)發(fā)者面向接口編程,文中介紹的非常詳細(xì),需要的朋友可以參考下
    2024-10-10
  • 一篇文章徹底弄懂SpringBoot項(xiàng)目jdk版本及依賴不兼容問(wèn)題

    一篇文章徹底弄懂SpringBoot項(xiàng)目jdk版本及依賴不兼容問(wèn)題

    這篇文章主要給大家介紹了關(guān)于徹底弄懂SpringBoot項(xiàng)目jdk版本及依賴不兼容問(wèn)題的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-01-01

最新評(píng)論