為什么JDK8中HashMap依然會死循環(huán)
JDK8中HashMap依然會死循環(huán)!
是否你聽說過JDK8之后HashMap已經(jīng)解決的擴容死循環(huán)的問題,雖然HashMap依然說線程不安全,但是不會造成服務器load飆升的問題。
然而事實并非如此。少年可曾了解一種紅黑樹成環(huán)的場景,=v=
今日在查看監(jiān)控時候發(fā)現(xiàn),某一臺機器load飆升
感覺問題不對勁,ssh大法登陸機器,top,top -Hp,jstack,jmap四連擊保存下來堆棧,cpu使用最高的線程,內(nèi)存信息準備分析。
首先查看使用最耗費cpu的線程堆棧信息
cat stack | grep -i 34670 -C10 --color
我勒個去,HashMap,猜測八成死循環(huán)了,但是我們使用的JDK8,在8中通過棧封閉的鏈表替換,解決了擴容死循環(huán)的問題。疑惑,繼續(xù)往下看。
根據(jù)堆棧信息,root方法是問題所在,點開HashMap源碼
好嘛,load飆高,代碼有個for語句,我覺得鐵定死循環(huán)了,看代碼情況只可能是兩個紅黑樹節(jié)點的父親節(jié)點相互引用才可以導致無法走出這個for語句。
然而這都是我的猜測,我沒有證據(jù)。而且讓我追紅黑樹的代碼,也是需要耗費大量時間的事情,我需要快速驗證我的猜測。
我之前dump下來了堆內(nèi)存信息,我通過jhat 命令生成html的內(nèi)存信息頁面
然后輸入http://localhost:7000查看
我先找業(yè)務代碼中持有這個HashMap的對象,然后點進去查詢內(nèi)部信息
因為數(shù)據(jù)都放在table中,點擊Table字段,查看其內(nèi)容
table中存在唯一的一個TreeNode節(jié)點,這肯定是已經(jīng)變成了紅黑樹了
點進去查看
點擊parent字段信息
0x72745d828與0x72745d7b8兩個TreeNode節(jié)點的Parent引用都是對方。
后續(xù)打算深入研究一下紅黑樹什么場景會造成這個原因。
最后,無論什么并發(fā)場景請別使用HashMap,ConcurrentHashmap大法好
到此這篇關于為什么JDK8中HashMap依然會死循環(huán)的文章就介紹到這了,更多相關JDK8 HashMap死循環(huán)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
在springboot項目中同時接收文件和多個參數(shù)的方法總結(jié)
在開發(fā)接口中,遇到了需要同時接收文件和多個參數(shù)的情況,可以有多種方式實現(xiàn)文件和參數(shù)的同時接收,文中給大家介紹了兩種實現(xiàn)方法,感興趣的同學跟著小編一起來看看吧2023-08-08java+io+swing實現(xiàn)學生信息管理系統(tǒng)
這篇文章主要為大家詳細介紹了java+io+swing實現(xiàn)學生信息管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07Spring Boot 3.x 集成 Eureka Server/Cl
隨著SpringBoot 3.x版本的開發(fā)嘗試,本文記錄了在集成Eureka Server/Client時所遇到的問題和解決方案,文中詳細介紹了搭建服務、配置文件和測試步驟,感興趣的朋友跟隨小編一起看看吧2024-09-09application.yml文件中如何開啟mybatis自動駝峰映射
這篇文章主要介紹了application.yml文件中開啟mybatis自動駝峰映射的方法,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-08-08java怎么創(chuàng)建目錄(刪除/修改/復制目錄及文件)代碼實例
這篇文章主要介紹了java怎么創(chuàng)建目錄,還包括刪除/修改/復制目錄及文件,代碼簡單,下面直接看代碼吧2013-12-12