今天就跟大家聊聊有關JDK8中HashMap會死循環的原因,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
首先查看使用最耗費cpu的線程堆棧信息
cat stack | grep -i 34670 -C10 --color
我勒個去,HashMap,猜測八成死循環了,但是我們使用的JDK8,在8中通過棧封閉的鏈表替換,解決了擴容死循環的問題。疑惑,繼續往下看。
根據堆棧信息,root方法是問題所在,點開HashMap源碼
好嘛,load飆高,代碼有個for語句,我覺得鐵定死循環了,看代碼情況只可能是兩個紅黑樹節點的父親節點相互引用才可以導致無法走出這個for語句。
然而這都是我的猜測,我沒有證據。而且讓我追紅黑樹的代碼,也是需要耗費大量時間的事情,我需要快速驗證我的猜測。
我之前dump下來了堆內存信息,我通過jhat 命令生成html的內存信息頁面
然后輸入http://localhost:7000查看
我先找業務代碼中持有這個HashMap的對象,然后點進去查詢內部信息
因為數據都放在table中,點擊Table字段,查看其內容
table中存在唯一的一個TreeNode節點,這肯定是已經變成了紅黑樹了
點進去查看
點擊parent字段信息
0x72745d828與0x72745d7b8兩個TreeNode節點的Parent引用都是對方。
后續打算深入研究一下紅黑樹什么場景會造成這個原因。
看完上述內容,你們對JDK8中HashMap會死循環的原因有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。