hashmap中的一些小點(diǎn)(個(gè)人總結(jié))

  • capacity <<= 1:
            int i  = 1;

          //類(lèi)似于 i++就是 i = i+1;的這結(jié)構(gòu)
          //i = i<<1  i等于i乘以2的1次方
          //i <<= 1;
          //i = i<<2  i等于i乘以2的2次方,>>就是相除了
          i <<= 2;
          System.out.println("結(jié)果是:" + i);
  • java中有三種移位運(yùn)算符:

// <<:左移運(yùn)算符,num << 1,相當(dāng)于num乘以2
// >>:右移運(yùn)算符未巫,num >> 1,相當(dāng)于num除以2
// >>>:無(wú)符號(hào)右移荣瑟,忽略符號(hào)位,空位都以0補(bǔ)齊
無(wú)符號(hào)右移的規(guī)則只記住一點(diǎn):忽略了符號(hào)位擴(kuò)展,0補(bǔ)最高位 無(wú)符號(hào)右移運(yùn)算符>>> 只是對(duì)32位和64位的值有意義

            //保證hashCode 不同的算法
            //int 是4位byte的 4*8=32bit 间聊,注意-->12+20=32
           //h>>>20是無(wú)符號(hào)右移運(yùn)算,就是將int類(lèi)型的h的二進(jìn)制數(shù)字位往右移動(dòng)抵拘,左邊移出來(lái)的空位補(bǔ)上0哎榴。
           //即為h = h ^ ((h >>> 20) ^ (h >>> 12));按位異或運(yùn)算,僅當(dāng)兩個(gè)對(duì)應(yīng)的二進(jìn)制位不相同時(shí)僵蛛,結(jié)果為1尚蝌;否則結(jié)果為0。
          static int hash(int h) {
             h ^= (h >>> 20) ^ (h >>> 12);
             return h ^ (h >>> 7) ^ (h >>> 4);
         }
  • 什么是哈希沖突:
  • 哈希計(jì)算就是努力的把比較大的數(shù)據(jù)存放到相對(duì)較小的空間中充尉。最常見(jiàn)的哈希算法是取模法飘言。
  • 取模法:數(shù)組的長(zhǎng)度是5。這時(shí)有一個(gè)數(shù)據(jù)是6驼侠。那么如何把這個(gè)6存放到長(zhǎng)度只有5的數(shù)組中呢姿鸿。按照取模法谆吴,計(jì)算6%5,結(jié)果是1般妙,那么就把6放到數(shù)組下標(biāo)是1的位置纪铺。那么,7就應(yīng)該放到2這個(gè)位置碟渺。到此位置鲜锚,沖突還沒(méi)有出現(xiàn)。這時(shí)苫拍,有個(gè)數(shù)據(jù)是11芜繁,按照取模法,11%5=1绒极,也等于1骏令。那么原來(lái)數(shù)組下標(biāo)是1的地方已經(jīng)有數(shù)了,是6垄提。這時(shí)又計(jì)算出1這個(gè)位置榔袋,那么數(shù)組1這個(gè)位置,就必須儲(chǔ)存兩個(gè)數(shù)了铡俐。這時(shí)凰兑,就叫哈希沖突。沖突之后就要按照順序來(lái)存放了审丘。
  • 如果數(shù)據(jù)的分布比較廣泛吏够,而且儲(chǔ)存數(shù)據(jù)的數(shù)組長(zhǎng)度比較大。那么哈希沖突就比較少滩报。否則沖突是很高的锅知。

HashMap就是一個(gè)散列表,它是通過(guò)“拉鏈法”解決哈希沖突的

  • 什么是拉鏈法:
  • 拉鏈法又叫鏈地址法脓钾,拉鏈法就是把具有相同散列地址的關(guān)鍵字(同義詞)值放在同一個(gè)單鏈表中售睹,稱(chēng)為同義詞鏈表。有m個(gè)散列地址就有m個(gè)鏈表惭笑,同時(shí)用指針數(shù)組T[0..m-1]存放各個(gè)鏈表的頭指針侣姆,凡是散列地址為i的記錄都以結(jié)點(diǎn)方式插入到以T[i]為指針的單鏈表中。T中各分量的初值應(yīng)為空指針.
  • 簡(jiǎn)單來(lái)說(shuō)拉鏈法就是數(shù)組加鏈表沉噩。
  • 大方向上,HashMap 里面是一個(gè)數(shù)組柱蟀,然后數(shù)組中每個(gè)元素是一個(gè)單向鏈表川蒙。
    下圖中,每個(gè)綠色的實(shí)體是嵌套類(lèi) Entry 的實(shí)例长已,Entry 包含四個(gè)屬性:key, value, hash 值和用于單向鏈表的 next畜眨。
這個(gè)僅僅是示意圖昼牛,因?yàn)闆](méi)有考慮到數(shù)組要擴(kuò)容的情況

從HashMap的實(shí)現(xiàn)來(lái)看,我們總結(jié)拉鏈法的實(shí)現(xiàn)步驟如下:
1. 計(jì)算 key 的 hashValue
2. 根據(jù) hashValue 值定位到 table[hashIndex] 康聂。( table[hashIndex] 是一條鏈表Node)
3. 若 table[hashValue] 為空則直接插入贰健,不然則添加到鏈表末尾


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市恬汁,隨后出現(xiàn)的幾起案子伶椿,更是在濱河造成了極大的恐慌,老刑警劉巖氓侧,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件脊另,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡约巷,警方通過(guò)查閱死者的電腦和手機(jī)偎痛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)独郎,“玉大人踩麦,你說(shuō)我怎么就攤上這事∶グ” “怎么了谓谦?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)顽铸。 經(jīng)常有香客問(wèn)我茁计,道長(zhǎng),這世上最難降的妖魔是什么谓松? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任星压,我火速辦了婚禮,結(jié)果婚禮上鬼譬,老公的妹妹穿的比我還像新娘娜膘。我一直安慰自己,他們只是感情好优质,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布竣贪。 她就那樣靜靜地躺著,像睡著了一般巩螃。 火紅的嫁衣襯著肌膚如雪演怎。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,679評(píng)論 1 305
  • 那天避乏,我揣著相機(jī)與錄音爷耀,去河邊找鬼。 笑死拍皮,一個(gè)胖子當(dāng)著我的面吹牛歹叮,可吹牛的內(nèi)容都是我干的跑杭。 我是一名探鬼主播,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼咆耿,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼德谅!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起萨螺,我...
    開(kāi)封第一講書(shū)人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤窄做,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后屑迂,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體浸策,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年惹盼,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了庸汗。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡手报,死狀恐怖蚯舱,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情掩蛤,我是刑警寧澤枉昏,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站揍鸟,受9級(jí)特大地震影響兄裂,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜阳藻,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一晰奖、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧腥泥,春花似錦匾南、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至夹厌,卻和暖如春豹爹,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背矛纹。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工帅戒, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人崖技。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓逻住,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親迎献。 傳聞我的和親對(duì)象是個(gè)殘疾皇子瞎访,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355