日本一区二区三区久久久久久久久不_日韩精品一区二区三区三区免费_精品视频一区二区不卡_欧美剧情片在线观看_欧美日韩免费在线视频_欧美成人精品3d动漫h_欧美激情中文字幕一区二区_91色九色蝌蚪_国产做a爰片久久毛片_久久久国产午夜精品_美女视频免费一区_日韩一级免费观看_日本一区二区三区四区在线视频_亚洲三级小视频_久久男人中文字幕资源站_欧美岛国在线观看

二維碼
企資網(wǎng)

掃一掃關(guān)注

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

Java中HashMap常見(jiàn)問(wèn)題____擴(kuò)容_

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

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

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

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

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

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

    ?♂?樹(shù)化一定更好么?

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

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

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

    為什么需要二次哈希

    先獲得key得hashCode得值 h,然后 h 和 h右移16位 做異或運(yùn)算。
    實(shí)質(zhì)上是把一個(gè)數(shù)得末x位低16位與他得高16位做異或運(yùn)算,因?yàn)樵谇懊?(n - 1) & hash 得計(jì)算中,hash變量只有末x位會(huì)參與到運(yùn)算。使高16位也參與到hash得運(yùn)算能減少?zèng)_突

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

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

    為了方便擴(kuò)容

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

    因?yàn)镠ashMap得初始容量是2得次冪,擴(kuò)容之后得長(zhǎng)度是原來(lái)得二倍,新得容量也是2得次冪,所以,元素,要么在原位置,要么在原位置再移動(dòng)2得次冪。

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

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

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

    不用2得n次方可以么

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

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

    注意

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

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

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

    主要是第壹個(gè)節(jié)點(diǎn)才會(huì)吧?因?yàn)榈谝紓€(gè)是new Node出來(lái)得

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

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

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

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


    原文鏈接:juejin/post/7160661444143841288

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

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

    粵ICP備16078936號(hào)

    微信

    關(guān)注
    微信

    微信二維碼

    WAP二維碼

    客服

    聯(lián)系
    客服

    聯(lián)系客服:

    在線QQ: 303377504

    客服電話: 020-82301567

    E_mail郵箱: weilaitui@qq.com

    微信公眾號(hào): weishitui

    客服001 客服002 客服003

    工作時(shí)間:

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

    反饋

    用戶
    反饋

    日本一区二区三区久久久久久久久不_日韩精品一区二区三区三区免费_精品视频一区二区不卡_欧美剧情片在线观看_欧美日韩免费在线视频_欧美成人精品3d动漫h_欧美激情中文字幕一区二区_91色九色蝌蚪_国产做a爰片久久毛片_久久久国产午夜精品_美女视频免费一区_日韩一级免费观看_日本一区二区三区四区在线视频_亚洲三级小视频_久久男人中文字幕资源站_欧美岛国在线观看
    亚洲一区二区视频在线| 国产视频亚洲色图| 日本在线高清视频一区| 精品午夜一区二区三区| 欧美日韩在线不卡一区| 日韩亚洲视频在线| 日本高清一区| 色狠狠桃花综合| 欧美精品少妇一区二区三区| 91精选在线观看| 2021久久国产精品不只是精品| 久久久久久久久久久99999| 久久精品人人爽人人爽| 国产精品久久久久久久久免费丝袜 | 26uuu国产日韩综合| 欧美国产成人在线| 亚洲黄色免费电影| 美女视频网站久久| 丁香婷婷综合色啪| 国产麻豆日韩| 一本色道久久综合亚洲aⅴ蜜桃| 在线播放中文一区| 欧美国产综合色视频| 亚洲电影一级黄| 国产米奇在线777精品观看| 成人动漫在线视频| 亚洲一一在线| 欧美精品一区二区在线观看| 亚洲欧美色图小说| 黄色日韩三级电影| 国产精品一 二 三| 欧美性大战久久久久久久蜜臀| 久久尤物电影视频在线观看| 一区二区三区蜜桃网| 国产一区 二区 三区一级| 国产精品美女xx| 欧美亚洲精品一区| 国产精品免费人成网站| 日本欧美韩国一区三区| a级精品国产片在线观看| 日韩成人av电影在线| 日韩精品一区二区三区视频播放 | 国产精品欧美久久久久一区二区| 一区二区三区四区蜜桃| 狠狠色狠狠色合久久伊人| 国产乱码一区| 欧美精品少妇一区二区三区| 亚洲视频资源在线| 国产激情精品久久久第一区二区 | 久久久影视传媒| 日韩精品欧美成人高清一区二区| 99精品视频在线播放观看| 尤物一区二区三区| 久久久国产午夜精品| 全国精品久久少妇| 精品高清视频| 精品国产sm最大网站| 麻豆久久久久久久| 久久久久天天天天| 久久久亚洲精品一区二区三区| 奇米四色…亚洲| 精品无人区一区二区三区竹菊| 欧美一区二区在线视频| 日韩精品一区第一页| 精品蜜桃一区二区三区| 欧美精品一区在线观看| 黄色日韩三级电影| 亚洲成人第一| 欧美国产国产综合| 不卡一区二区中文字幕| 欧美日韩国产经典色站一区二区三区| 亚洲一区二区三区激情| 国产伦一区二区三区色一情| 日韩一级片在线播放| 日本欧美一区二区| 欧美下载看逼逼| 中文字幕av不卡| 99视频一区二区三区| 欧美日韩国产另类一区| 免费在线观看不卡| 一区二区三区四区不卡| 亚洲精品综合在线| 国产精品三区在线| 国产日韩综合av| www.爱久久.com| 日韩美女在线视频| 国产精品综合一区二区| 欧美三级电影一区| 另类小说色综合网站| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 日韩精品欧美专区| 亚洲美女电影在线| 国产无套精品一区二区| 国产伦一区二区三区色一情| 日韩精品中文字幕一区| 国产精品99久久久久久久女警| 欧美日韩国产乱码电影| 久久精品国产秦先生| 欧美天堂亚洲电影院在线播放| 另类小说欧美激情| 91久久精品一区二区三| 日本不卡视频在线| 欧美午夜精品一区| 国产在线播放一区| 日韩三级视频在线看| 99视频在线精品| 欧美国产激情一区二区三区蜜月| 国产精品9999久久久久仙踪林| 国产欧美精品一区aⅴ影院| 91色婷婷久久久久合中文| 欧美激情在线一区二区三区| 国产视频99| 亚洲线精品一区二区三区| 亚洲一区二区三区欧美| 美女高潮久久久| 欧美一区二区三区视频在线| 成人激情免费视频| 亚洲国产激情av| 日本一区精品| 蜜桃av噜噜一区| 欧美一区中文字幕| av噜噜色噜噜久久| 亚洲综合激情小说| 欧美亚洲一区二区在线观看| 国产成人一区在线| 国产精品视频一二三区| 欧洲在线视频一区| 激情综合色综合久久综合| 久久综合九色综合97婷婷| 国产视频一区二区三区四区| 亚洲成人av在线电影| 欧美军同video69gay| 4444kk亚洲人成电影在线| 亚洲欧美国产高清| 日本韩国精品一区二区在线观看| 国产精品一品视频| 国产精品色一区二区三区| 日韩精品伦理第一区| 激情综合网av| 欧美国产日韩在线观看| 一级二级三级欧美| 成人免费高清视频| 亚洲国产精品影院| 欧美一级视频精品观看| 久久国产精品一区二区三区四区| 免费高清在线一区| 欧美极品少妇xxxxⅹ高跟鞋| 一本一本久久a久久精品综合麻豆| 粉嫩绯色av一区二区在线观看| 国产精品久久免费看| 欧美视频一区二区| 国产精品香蕉视屏| 精品一区二区在线免费观看| 久久精品一区蜜桃臀影院| 一区二区三区四区国产| av不卡免费在线观看| 五月婷婷久久综合| 久久精品这里都是精品| 色天使色偷偷av一区二区| 成人欧美一区二区三区白人| 色播亚洲婷婷| 91精品国产一区二区三区动漫 | 天天综合天天综合色| 欧美成人一区二区三区片免费| 美日韩免费视频| 粉嫩av一区二区三区| 亚洲国产一区在线观看| 久久久久国产免费免费| 色8久久精品久久久久久蜜| 成人区精品一区二区| 激情成人午夜视频| 亚洲免费观看高清完整版在线观看 | 亚洲欧洲在线观看av| 91精品久久久久久蜜臀| 日韩av电影免费在线观看| 99热精品一区二区| 久久激情五月激情| 一区二区三区免费观看| 国产喷白浆一区二区三区| 欧美另类久久久品| 无码免费一区二区三区免费播放| 91精品黄色| 成人综合日日夜夜| 久久99精品国产麻豆婷婷 | 青草国产精品久久久久久| 中文字幕欧美日本乱码一线二线 | 亚洲精品视频一区二区| 精品乱码亚洲一区二区不卡| 欧美日韩精品一区二区| 色综合天天综合给合国产| 久久伊人一区| 国产福利一区二区三区在线观看| 成人网男人的天堂| 国产麻豆欧美日韩一区| 免费观看久久久4p| 首页亚洲欧美制服丝腿| 一区二区三区精品久久久| 国产精品电影院| 国产精品久久久久久久久动漫| 久久色在线视频|