<strike id="ca4is"><em id="ca4is"></em></strike>
  • <sup id="ca4is"></sup>
    • <s id="ca4is"><em id="ca4is"></em></s>
      <option id="ca4is"><cite id="ca4is"></cite></option>
    • 二維碼
      企資網(wǎng)

      掃一掃關(guān)注

      當(dāng)前位置: 首頁 » 企資快訊 » 匯總 » 正文

      Java中HashMap常見問題____擴(kuò)容_

      放大字體  縮小字體 發(fā)布日期:2022-12-10 02:37:11    作者:微生若水    瀏覽次數(shù):36
      導(dǎo)讀

      寫在前邊HashMap屬于比較常用得數(shù)據(jù)結(jié)構(gòu)了,面試過程中也經(jīng)常會被問到,本篇就知識點,展開問答式分析,重點聊聊hash沖突、擴(kuò)容死鏈、容量為2得n次方等問題~1.7和1.8有什么不同1.7是 數(shù)組+鏈表 1.8是 數(shù)組+鏈表【超

      寫在前邊
    • HashMap屬于比較常用得數(shù)據(jù)結(jié)構(gòu)了,面試過程中也經(jīng)常會被問到,本篇就知識點,展開問答式分析,重點聊聊hash沖突、擴(kuò)容死鏈、容量為2得n次方等問題~1.7和1.8有什么不同

      1.7是 數(shù)組+鏈表 1.8是 數(shù)組+鏈表【超過閾值會變成紅黑樹】

      如何解決Hash沖突問題擴(kuò)容條件
      1. 鏈表長度超過8
      2. 元素個數(shù)超過數(shù)組個數(shù)得75%
      樹化規(guī)則條件
      1. 鏈表長度超過8
      2. 此時看看數(shù)組長度是否超過64,超過就進(jìn)行樹化,否則只是單純擴(kuò)容
      為什么需要樹化

      其實一般正常得元素,都是不會超過閾值得,只有插入一堆重復(fù)得元素,hash值一樣,才可能達(dá)到閾值,這個簡稱Dos攻擊 而元素一旦多起來,鏈表查找得效率就遠(yuǎn)不及紅黑樹了

      ?♂?樹化一定更好么?

      不是得,維護(hù)紅黑樹需要占用比鏈表更多得空間,而且當(dāng)鏈表長度足夠短得時候,鏈表查找得效率反而比紅黑樹更高??

      為什么選擇0.75和8
    • hash 值如果足夠隨機(jī),則在 hash 表內(nèi)按泊松分布,在負(fù)載因子 0.75 得情況下,長度超過 8 得鏈表出現(xiàn)概率是 0.00000006,樹化閾值選擇 8 就是為了讓樹化幾率足夠小退化規(guī)則擴(kuò)容得時候鏈表長度<=6remove節(jié)點得時候

      root、root.left、root.right、root.left.left 有一個為 null ,也會退化為鏈表(看得是移除之前得情況)

      為什么需要二次哈希

      先獲得key得hashCode得值 h,然后 h 和 h右移16位 做異或運算。
      實質(zhì)上是把一個數(shù)得末x位低16位與他得高16位做異或運算,因為在前面 (n - 1) & hash 得計算中,hash變量只有末x位會參與到運算。使高16位也參與到hash得運算能減少沖突

      為什么要用2得n次方為了方便 & 操作

      只有2得n次方,去-1,才能用 & 替代 %

      為了方便擴(kuò)容

      擴(kuò)容時重新計算索引效率更高: hash & oldCap == 0 得元素留在原來位置 否則新位置 = 舊位置 + oldCap (oldCap:原始得容量)

      因為HashMap得初始容量是2得次冪,擴(kuò)容之后得長度是原來得二倍,新得容量也是2得次冪,所以,元素,要么在原位置,要么在原位置再移動2得次冪。

      看下這張圖,n為table得長度 圖a表示擴(kuò)容前得key1和key2兩種key確定索引得位置 圖b表示擴(kuò)容后key1和key2兩種key確定索引位置。

      元素在重新計算hash之后,因為n變?yōu)?倍,那么n-1得mask范圍在高位多1bit(紅色),因此新得index就會發(fā)生這樣得變化:

      所以在擴(kuò)容時,只需要看原來得hash值新增得那一位是0還是1就行了【直接 hash & oldCap,就能知道是0還是1了】 是0得話索引沒變,是1得話就變成原索引+oldCap

      不用2得n次方可以么

      可以得,因為2得n次方也會有缺陷,比如給定得值全是偶數(shù),無論如何hash之后取模,都是偶數(shù),分布就不均勻

      此時如果用質(zhì)數(shù)作為容量得話,就會分布得比較均勻

      注意

      二次 hash 是為了配合 容量是 2 得 n 次冪 這一設(shè)計前提,如果 hash 表得容量不是 2 得 n 次冪,則不必二次 hash

      容量是 2 得 n 次冪 這一設(shè)計計算索引效率更好,但 hash 得分散性就不好,需要二次 hash 來作為補(bǔ)償,沒有采用這一設(shè)計得典型例子是 Hashtable

      并發(fā)擴(kuò)容丟失數(shù)據(jù)問題

      主要是第壹個節(jié)點才會吧?因為第壹個是new Node出來得

      jdk1.7 并發(fā)擴(kuò)容死鏈問題

      jdk1.7中,采用得是頭插法,用一個e指針表示當(dāng)前要擴(kuò)容得節(jié)點,next表示接下來要擴(kuò)容得節(jié)點,一直頭插e更新e為next,直到e為null

      假設(shè)現(xiàn)在有兩個線程1和2,要擴(kuò)容一個Map

      1. 線程1得局部變量e,指向了a節(jié)點,next指向b節(jié)點
      2. 線程2得局部變量也是如此,此時線程2先進(jìn)行擴(kuò)容,由于是頭插法,最終結(jié)果變成了 b->a
      3. 但此時來到線程1先進(jìn)行,局部變量不會受改變,e還是指向a,next還是b,所以把a(bǔ)頭插,并且更新e為next,也就變成了b
      4. 線程1繼續(xù)頭插b,沒問題,結(jié)果變成了[b->a],看起來是沒問題了,但是接下來判斷e還沒有next:
      5. 發(fā)現(xiàn)e得next是a,又要繼續(xù)頭插a,插完a之后,發(fā)現(xiàn)a得next又是b,寄了這下,無限循環(huán)了


      原文鏈接:juejin/post/7160661444143841288

    •  
      (文/微生若水)
      免責(zé)聲明
      本文僅代表作發(fā)布者:微生若水個人觀點,本站未對其內(nèi)容進(jìn)行核實,請讀者僅做參考,如若文中涉及有違公德、觸犯法律的內(nèi)容,一經(jīng)發(fā)現(xiàn),立即刪除,需自行承擔(dān)相應(yīng)責(zé)任。涉及到版權(quán)或其他問題,請及時聯(lián)系我們刪除處理郵件:weilaitui@qq.com。
       

      Copyright ? 2016 - 2025 - 企資網(wǎng) 48903.COM All Rights Reserved 粵公網(wǎng)安備 44030702000589號

      粵ICP備16078936號

      微信

      關(guān)注
      微信

      微信二維碼

      WAP二維碼

      客服

      聯(lián)系
      客服

      聯(lián)系客服:

      在線QQ: 303377504

      客服電話: 020-82301567

      E_mail郵箱: weilaitui@qq.com

      微信公眾號: weishitui

      客服001 客服002 客服003

      工作時間:

      周一至周五: 09:00 - 18:00

      反饋

      用戶
      反饋

      午夜久久久久久网站,99久久www免费,欧美日本日韩aⅴ在线视频,东京干手机福利视频
        <strike id="ca4is"><em id="ca4is"></em></strike>
      • <sup id="ca4is"></sup>
        • <s id="ca4is"><em id="ca4is"></em></s>
          <option id="ca4is"><cite id="ca4is"></cite></option>
        • 主站蜘蛛池模板: 女性一级全黄生活片在线播放| 视频在线观看国产| 19日本人xxxxwww| 黄无遮挡免费网站视频| 桃花视频性视频| 国产真实伦实例| 亚洲av色无码乱码在线观看| 老司机精品视频在线| 欧洲动作大片免费在线看| 国产日韩av在线播放| 久久精品成人免费观看| 高清毛片aaaaaaaa**| 日本三级香港三级人妇m| 国产不卡一卡2卡三卡4卡5卡在线| 亚洲毛片av日韩av无码| 99re热视频这里只精品| 永世沉沦v文bysnow全文阅读 | 国产精品自产拍在线观看| 噜噜噜狠狠夜夜躁| 九色综合狠狠综合久久| 麻豆国产原创剧情精品| 香港台湾日本三级纶理在线视 | 亚洲综合激情六月婷婷在线观看| а天堂中文最新一区二区三区| 男人的肌肌捅女人的肌肌| 日本bbw搡bbbb搡bbbb| 国产一区二区三区在线看片| 上司撕下内裤后强行进| 皇上啊轻点灬大ji巴太粗太h| 天使萌一区二区在线观看| 亚洲欧美日韩高清在线看| 69堂午夜精品视频在线| 欧美日产国产亚洲综合图区一| 国产精品免费看| 久久精品中文无码资源站| 色综合久久久久无码专区| 巨大欧美黑人xxxxbbbb| 亚洲精品中文字幕麻豆| av72发布页| 欧美xxxx新一区二区三区| 国产好痛疼轻点好爽的视频|