<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          啥?HashMap 1.8 還有死循環(huán)?你逗我呢!

          共 1052字,需瀏覽 3分鐘

           ·

          2020-09-23 02:37


          是否你聽說過JDK8之后HashMap已經(jīng)解決的擴(kuò)容死循環(huán)的問題,雖然HashMap依然說線程不安全,但是不會(huì)造成服務(wù)器load飆升的問題。

          然而事實(shí)并非如此。少年可曾了解一種紅黑樹成環(huán)的場(chǎng)景,=v=

          今日,在查看監(jiān)控時(shí)候發(fā)現(xiàn),某一臺(tái)機(jī)器load飆升

          感覺問題不對(duì)勁,ssh大法登陸機(jī)器,top,top -Hp,jstack,jmap四連擊保存下來堆棧,cpu使用最高的線程,內(nèi)存信息準(zhǔn)備分析。

          首先查看使用最耗費(fèi)cpu的線程堆棧信息
          cat stack | grep -i 34670 -C10 --color
          我勒個(gè)去,HashMap,猜測(cè)八成死循環(huán)了,但是我們使用的JDK8,在8中通過棧封閉的鏈表替換,解決了擴(kuò)容死循環(huán)的問題。疑惑,繼續(xù)往下看。

          根據(jù)堆棧信息,root方法是問題所在,點(diǎn)開HashMap源碼
          好嘛,load飆高,代碼有個(gè)for語(yǔ)句,我覺得鐵定死循環(huán)了,看代碼情況只可能是兩個(gè)紅黑樹節(jié)點(diǎn)的父親節(jié)點(diǎn)相互引用才可以導(dǎo)致無(wú)法走出這個(gè)for語(yǔ)句。

          然而這都是我的猜測(cè),我沒有證據(jù)。而且讓我追紅黑樹的代碼,也是需要耗費(fèi)大量時(shí)間的事情,我需要快速驗(yàn)證我的猜測(cè)。

          我之前dump下來了堆內(nèi)存信息,我通過jhat 命令生成html的內(nèi)存信息頁(yè)面
          然后輸入http://localhost:7000查看。

          我先找業(yè)務(wù)代碼中持有這個(gè)HashMap的對(duì)象,然后點(diǎn)進(jìn)去查詢內(nèi)部信息

          因?yàn)閿?shù)據(jù)都放在table中,點(diǎn)擊Table字段,查看其內(nèi)容
          table中存在唯一的一個(gè)TreeNode節(jié)點(diǎn),這肯定是已經(jīng)變成了紅黑樹了

          點(diǎn)進(jìn)去查看


          點(diǎn)擊parent字段信息
          0x72745d828與0x72745d7b8兩個(gè)TreeNode節(jié)點(diǎn)的Parent引用都是對(duì)方。
          后續(xù)打算深入研究一下紅黑樹什么場(chǎng)景會(huì)造成這個(gè)原因。

          最后,無(wú)論什么并發(fā)場(chǎng)景請(qǐng)別使用HashMap,ConcurrentHashmap大法好~
          作者:Aaron_濤
          來源:blog.csdn.net/qq_33330687/article/details/101479385


          推薦閱讀

          InnoDB索引允許NULL對(duì)性能有影響嗎

          Mysql的binlog和relay-log到底長(zhǎng)啥樣?

          漲姿勢(shì):為啥MySQL官方不推薦使用uuid或者雪花id作為主鍵?

          瀏覽 25
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          評(píng)論
          圖片
          表情
          推薦
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  欧洲性爱AV | 婷婷五月天亚洲 | 成年人黄色视频在线观看 | 麻豆91AV | 人人操人人妻 |