精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

面試突擊:說一下HashMap底層實現?及元素添加流程?

開發 前端
HashMap 是使用頻率最高的數據類型之一,同時也是面試必問的問題之一,尤其是它的底層實現原理,既是常見的面試題又是理解 HashMap 的基石,所以重要程度不言而喻。

HashMap 是使用頻率最高的數據類型之一,同時也是面試必問的問題之一,尤其是它的底層實現原理,既是常見的面試題又是理解 HashMap 的基石,所以重要程度不言而喻。

HashMap 底層實現

HashMap 在 JDK 1.7 和 JDK 1.8 的底層實現是不一樣的,在 JDK 1.7 中,HashMap 使用的是數組 + 鏈表實現的,而 JDK 1.8 中使用的是數組 + 鏈表或紅黑樹實現的。HashMap 在 JDK 1.7 中的實現如下圖所示:

HashMap 在 JDK 1.8 中的實現如下圖所示:

我們本文重點來學習主流版本 JDK 1.8 中的 HashMap。HashMap 中每個元素稱之為一個哈希桶(bucket),哈希桶包含的內容有 4 個:

  • hash 值
  • key
  • value
  • next(下一個節點)

HashMap 插入流程

HashMap 元素新增的實現源碼如下(下文源碼都是基于主流版本 JDK 1.8):

  1. public V put(K key, V value) { 
  2.     // 對 key 進行哈希操作 
  3.     return putVal(hash(key), key, value, falsetrue); 
  4. final V putVal(int hash, K key, V value, boolean onlyIfAbsent, 
  5.                boolean evict) { 
  6.     Node<K,V>[] tab; Node<K,V> p; int n, i; 
  7.     // 哈希表為空則創建表 
  8.     if ((tab = table) == null || (n = tab.length) == 0) 
  9.         n = (tab = resize()).length; 
  10.     // 根據 key 的哈希值計算出要插入的數組索引 i 
  11.     if ((p = tab[i = (n - 1) & hash]) == null
  12.         // 如果 table[i] 等于 null,則直接插入 
  13.         tab[i] = newNode(hash, key, value, null); 
  14.     else { 
  15.         Node<K,V> e; K k; 
  16.         // 如果 key 已經存在了,直接覆蓋 value 
  17.         if (p.hash == hash && 
  18.             ((k = p.key) == key || (key != null && key.equals(k)))) 
  19.             e = p; 
  20.         // 如果 key 不存在,判斷是否為紅黑樹 
  21.         else if (p instanceof TreeNode) 
  22.             // 紅黑樹直接插入鍵值對 
  23.             e = ((TreeNode<K,V>)p).putTreeVal(this, tab, hash, key, value); 
  24.         else { 
  25.             // 為鏈表結構,循環準備插入 
  26.             for (int binCount = 0; ; ++binCount) { 
  27.                 // 下一個元素為空時 
  28.                 if ((e = p.next) == null) { 
  29.                     p.next = newNode(hash, key, value, null); 
  30.                     // 轉換為紅黑樹進行處理 
  31.                     if (binCount >= TREEIFY_THRESHOLD - 1) // -1 for 1st 
  32.                         treeifyBin(tab, hash); 
  33.                     break; 
  34.                 } 
  35.                 //  key 已經存在直接覆蓋 value 
  36.                 if (e.hash == hash && 
  37.                     ((k = e.key) == key || (key != null && key.equals(k)))) 
  38.                     break; 
  39.                 p = e; 
  40.             } 
  41.         } 
  42.         if (e != null) { // existing mapping for key 
  43.             V oldValue = e.value; 
  44.             if (!onlyIfAbsent || oldValue == null
  45.                 e.value = value; 
  46.             afterNodeAccess(e); 
  47.             return oldValue; 
  48.         } 
  49.     } 
  50.     ++modCount; 
  51.     // 超過最大容量,擴容 
  52.     if (++size > threshold) 
  53.         resize(); 
  54.     afterNodeInsertion(evict); 
  55.     return null

上述的源碼都添加了相應的代碼注釋,簡單來說 HashMap 的元素添加流程是,先將 key 值進行 hash 得到哈希值,根據哈希值得到元素位置,判斷元素位置是否為空,如果為空直接插入,不為空判斷是否為紅黑樹,如果是紅黑樹則直接插入,否則判斷鏈表是否大于 8,且數組長度大于 64,如果滿足這兩個條件則把鏈表轉成紅黑樹,然后插入元素,如果不滿足這兩個條件中的任意一個,則遍歷鏈表進行插入,它的執行流程如下圖所示:

為什么要將鏈表轉紅黑樹?

JDK 1.8 中引入了新的數據結構紅黑樹來實現 HashMap,主要是出于性能的考量。因為鏈表超過一定長度之后查詢效率就會很低,它的時間復雜度是 O(n),而紅黑樹的時間復雜度是 O(logn),因此引入紅黑樹可以加快 HashMap 在數據量比較大的情況下的查詢效率。

哈希算法實現

HashMap 的哈希算法實現源碼如下:

  1. static final int hash(Object key) { 
  2.     int h; 
  3.     return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16); 

其中,key.hashCode() 是 Java 中自帶的 hashCode() 方法,返回一個 int 類型的散列值,后面 hashCode 再右移 16 位,正好是 32bit 的一半,與自己本身做異或操作(相同為 0,不同為 1),主要是為了混合哈希值的高位和低位,增加低位的隨機性,這樣就實現了 HashMap 的哈希算法。

總結

HashMap 在 JDK 1.7 時,使用的是數組 + 鏈表實現的,而在 JDK 1.8 時,使用的是數組 + 鏈表或紅黑樹的方式來實現的,JDK 1.8 之所以引入紅黑樹主要是出于性能方面的考慮。HashMap 在插入時,會判斷當前鏈表的長度是否大于 8 且數組的長度大于 64,如果滿足這兩個條件就會把鏈表轉成紅黑樹再進行插入,否則就是遍歷鏈表插入。

參考文檔:https://tech.meituan.com/2016/06/24/java-hashmap.html

本文轉載自微信公眾號「Java面試真題解析」,可以通過以下二維碼關注。轉載本文請聯系Java面試真題解析公眾號。

 

責任編輯:武曉燕 來源: Java面試真題解析
相關推薦

2022-06-29 11:01:05

MySQL事務隔離級別

2022-09-27 21:14:54

Spring事務傳播機制

2022-09-05 07:06:59

BeanSpring

2022-05-18 07:43:09

Exchange交換器JUC

2023-02-06 07:01:51

2022-02-17 08:02:08

線程Java生命周期

2022-03-09 07:35:24

線程池線程參數

2022-07-20 07:29:55

TCPIP協議

2023-11-29 08:00:53

JavaTreeMap底層

2022-04-13 14:43:05

JVM同步鎖Monitor 監視

2024-02-27 15:23:48

RedLock算法Redis

2023-09-12 14:56:13

MyBatis緩存機制

2024-01-29 10:08:11

零拷貝Zero-copyCPU 拷貝

2025-03-10 07:05:07

2021-07-28 10:08:19

類加載代碼塊面試

2023-02-02 07:06:10

2022-06-07 12:03:33

Java內存模型

2022-06-06 15:33:20

線程Java釋放鎖

2023-02-08 08:32:41

輪詢鎖

2023-02-18 13:34:14

Nacos健康檢查機制
點贊
收藏

51CTO技術棧公眾號

亚洲成人自拍偷拍| 国产乱对白刺激视频不卡| 欧美精品一区二区蜜臀亚洲| 欧美性潮喷xxxxx免费视频看| 欧美一区二区三区黄片| 久久一区中文字幕| 久久久精品免费视频| 李丽珍裸体午夜理伦片| 亚洲电影有码| 一区二区三区四区乱视频| 精品视频第一区| 一区二区自拍偷拍| 亚洲日本免费| 日韩在线视频网| 国模无码视频一区| 免费成人高清在线视频| 亚洲风情在线资源站| 欧美亚洲免费高清在线观看| 亚洲天堂网在线观看视频| 在线精品一区| 日韩有码在线电影| 国产高清自拍视频| 日本少妇精品亚洲第一区| 色哟哟一区二区| www.亚洲视频.com| 888av在线| av资源站一区| 亚洲a成v人在线观看| 国产一区免费看| av成人激情| 久久中文精品视频| 久久国产柳州莫菁门| 欧美日韩一本| 精品国产乱码久久久久久久久| 香港日本韩国三级网站| 日本大片在线播放| 亚洲婷婷在线视频| 日韩欧美亚洲v片| 日韩在线观看视频一区| 国产精品中文字幕一区二区三区| 国产精品久久999| 五月天综合激情| 精品91在线| 欧美风情在线观看| 日韩在线观看视频一区二区| 日韩毛片视频| 在线不卡国产精品| 美女脱光内衣内裤| 亚洲动漫在线观看| 日韩国产精品视频| 99精品一区二区三区无码吞精| 国产亚洲精aa在线看| 欧美人成免费网站| 成人黄色一级大片| 久久久久黄色| 在线播放一区二区三区| 亚洲精品20p| **国产精品| 91精品欧美一区二区三区综合在| 日韩av在线中文| 久久免费资源| 欧美精品乱码久久久久久按摩| 亚洲第一狼人区| 久久久久久久性潮| 91精品国产综合久久久久久久| 性欧美1819| 亚洲ww精品| 日韩一区二区影院| 欧美图片自拍偷拍| 欧美一级一片| 亚洲色图狂野欧美| 91香蕉视频污在线观看| 91精品动漫在线观看| 欧美另类在线播放| 91久久国产视频| 久久先锋资源| 国产精品中文在线| 国产www免费观看| 成人av网站在线| 欧美精品国产精品久久久| 欧美精品少妇| 成人免费视频在线观看| 久久久久香蕉视频| 丁香花电影在线观看完整版| 一级女性全黄久久生活片免费| 在线视频一二三区| 黄色在线观看视频网站| 黑人巨大精品欧美一区免费视频| 88av.com| 国产精品亚洲一区二区在线观看| 日韩精品一区二区三区四区 | 久久资源av| 国产高清免费在线播放| 亚洲女同女同女同女同女同69| 白白操在线视频| 亚洲欧美电影| 91精品国产乱码| 亚洲精品中文字幕在线播放| 精品国产aⅴ| 欧美日韩电影在线观看| 亚洲av中文无码乱人伦在线视色| 蜜桃视频一区二区| 国产日韩亚洲精品| 免费在线你懂的| 亚洲va韩国va欧美va| 韩国中文字幕av| 久久av国产紧身裤| 不卡毛片在线看| 国产一卡二卡三卡| 国产成人高清视频| 亚洲一区二区在| 国模套图日韩精品一区二区| 日韩西西人体444www| 国产一级久久久久毛片精品| 黄色欧美成人| 91理论片午午论夜理片久久| 男人av在线| 精品久久久久久久久中文字幕| 91pony九色| 欧美午夜精品一区二区三区电影| 久久久免费精品| 国产美女精品视频国产| 国产婷婷色一区二区三区 | 免费一级黄色录像| 一本色道久久综合一区| 成人免费观看网站| 国产福利视频在线| 欧美日本一区二区| 国产伦理片在线观看| 在线视频精品| 国产精品一区二区三区在线| 国产一二区在线观看| 欧美吻胸吃奶大尺度电影| 久久精品综合视频| 在线欧美视频| 成人女人免费毛片| 免费在线观看的电影网站| 91.com在线观看| 老司机福利在线观看| 日日摸夜夜添夜夜添亚洲女人| 国产亚洲情侣一区二区无| 日本电影在线观看| 精品少妇一区二区| 欧美成人综合色| 国产91丝袜在线播放九色| 99精品一区二区三区的区别| 日韩大陆av| 精品激情国产视频| 在线观看中文字幕2021| 国产精品护士白丝一区av| 在线观看的毛片| 日本一区二区在线看| 国产精品久久色| 91社区在线观看| 欧美日韩精品二区第二页| 国产白丝一区二区三区| 麻豆国产欧美一区二区三区| 中文字幕av日韩精品| 亚州精品国产| 欧美高清不卡在线| 午夜视频免费看| 色综合色狠狠综合色| 天天舔天天操天天干| 麻豆国产精品777777在线| 尤物国产精品| 欧美特黄不卡| 国内免费精品永久在线视频| 外国精品视频在线观看 | 久无码久无码av无码| 狠狠一区二区三区| 秋霞av国产精品一区| 国产福利在线| 日韩一级精品视频在线观看| 伊人国产在线观看| 2020国产精品久久精品美国| 凹凸国产熟女精品视频| 日韩欧美中文| 国产精品毛片va一区二区三区| 免费一二一二在线视频| 一区二区三欧美| 国产高清第一页| 欧美日韩免费一区| 精品亚洲乱码一区二区 | av一区和二区| 中文字幕资源网在线观看免费| 国产亚洲欧洲在线| 国产精品久久影视| 午夜亚洲国产au精品一区二区| 人妻丰满熟妇aⅴ无码| 喷白浆一区二区| 欧美美女黄色网| 偷拍自拍亚洲色图| 91精品视频在线| 涩涩涩视频在线观看| 丝袜美腿亚洲一区二区| 日韩有码第一页| 欧美日韩美少妇| 久久狠狠高潮亚洲精品| 国产精品免费看片| 一区二区三区少妇| 国产一区二区三区四区五区美女| 少妇av一区二区三区无码| 色爱综合网欧美| 蜜桃在线一区二区三区精品| 国产一区二区三区视频在线| 日本高清不卡的在线| 一区二区三区伦理| 一本色道久久88亚洲综合88| 高潮毛片7777777毛片| 欧美在线你懂的| 黄色小说在线观看视频| 亚洲欧美偷拍另类a∨色屁股| www.17c.com喷水少妇| 精品一区二区三区久久久| 男人亚洲天堂网| 韩国在线一区| 日本黄色a视频| 九九热线有精品视频99| 国产高清精品一区二区| 亚洲欧美综合久久久久久v动漫| 日本不卡视频在线播放| 成人性生交大片免费看网站| 久久精品视频在线播放| 国产人成在线观看| 国产丝袜精品视频| 日韩一区免费视频| 欧美本精品男人aⅴ天堂| 中文字幕有码视频| 欧美怡红院视频| 波多野结衣视频网站| 亚洲一二三四在线| 青春草免费视频| 亚洲欧美aⅴ...| 日本黄色免费片| 国产精品网友自拍| 日韩中文字幕有码| 日本一区二区在线不卡| 国产jk精品白丝av在线观看| 91丨九色丨蝌蚪丨老版| 国产熟女高潮一区二区三区| 成人国产精品免费网站| 午夜男人的天堂| eeuss国产一区二区三区 | 国产精品女同一区二区| 精品视频色一区| 亚洲图片视频小说| 欧美日本一区二区| 国产特级黄色片| 日韩片之四级片| 不卡视频在线播放| 精品嫩草影院久久| 特黄视频在线观看| 日韩电影中文字幕av| 免费av网站在线播放| 亚洲国产精久久久久久| 亚洲 另类 春色 国产| 亚洲精品久久久久久久久久久久 | 麻豆成人免费视频| 在线观看亚洲一区| 在线播放精品视频| 欧美精品成人一区二区三区四区| 国产美女永久免费| 精品成a人在线观看| 天天色天天操天天射| 亚洲欧美日韩图片| 黄色片在线播放| 久久精品国产v日韩v亚洲| 在线视频观看国产| 午夜精品一区二区三区av| 波多野结衣亚洲| 国产一区红桃视频| 6080亚洲理论片在线观看| 国产精品一区二区三区在线观 | 国产高清亚洲一区| 理论片大全免费理伦片| 久久亚洲免费视频| 日本一二三区在线观看| 亚洲一区二区三区四区在线 | 欧美亚洲一级| 色悠悠久久综合网| 国产91露脸合集magnet| 一本加勒比北条麻妃| 中文字幕亚洲成人| 日本午夜小视频| 精品视频在线看| 国 产 黄 色 大 片| 亚洲网站在线播放| 深夜国产在线播放| 国产精品777| 日韩亚洲精品在线观看| 欧美久久久久久一卡四| 亚洲二区三区不卡| 国产成人a亚洲精v品无码| 精品一区二区在线视频| 久久性爱视频网站| 国产精品久久久久7777按摩 | 欧美日韩一区二区在线视频| 国产aⅴ爽av久久久久成人| 日韩精品亚洲元码| av网站大全在线| 国产mv久久久| 成人av地址| 一区二区三区四区欧美| 国产精品美女久久久浪潮软件| 一道本视频在线观看| www.在线欧美| 秋霞欧美一区二区三区视频免费| 无吗不卡中文字幕| 国产精品伦一区二区三区| 亚洲男人天堂久| 激情影院在线| 91色琪琪电影亚洲精品久久| 国产欧美日韩在线一区二区| 激情小视频网站| 久99久精品视频免费观看| 免费看黄色aaaaaa 片| 亚洲精品国产品国语在线app| 中文字幕在线观看视频免费| 亚洲第一视频网站| 污污片在线免费视频| 成人福利在线视频| 国产一区二区三区四区| 成人免费在线小视频| 成人在线一区二区三区| 91在线播放观看| 欧美人妇做爰xxxⅹ性高电影| 福利片在线看| 日韩av手机在线| 西野翔中文久久精品国产| 久艹视频在线免费观看| 高清成人在线观看| www.超碰在线观看| 在线播放国产精品二区一二区四区 | 国产美女高潮在线观看| 国产精品一区二区你懂得| 欧美日韩国产欧| 自拍一级黄色片| 亚洲视频一区二区在线| 国产美女三级无套内谢| 久久久国产精彩视频美女艺术照福利| 成人黄色视屏网站| 日韩在线电影一区| 天堂资源在线中文精品| 欧美做受高潮6| 在线亚洲人成电影网站色www| 青青久草在线| 日产精品99久久久久久| 精品国产乱码久久久久久果冻传媒| 日韩少妇内射免费播放18禁裸乳| 99久久精品免费| 九九九在线观看| 亚洲欧美日韩图片| 成人综合网站| 宅男av一区二区三区| 国产麻豆精品在线| 久久亚洲成人av| 亚洲精品v欧美精品v日韩精品| 国产三级电影在线播放| 另类视频在线观看+1080p| 日韩中文字幕亚洲一区二区va在线 | 日本福利视频网站| 成人av资源在线观看| 欧美三日本三级少妇99| 亚洲精品中文字幕有码专区| 日韩伦理三区| 国产精品jizz在线观看老狼| 国产精品亚洲第一区在线暖暖韩国 | 97精品免费视频| 中文字幕伦av一区二区邻居| 九热视频在线观看| 综合久久给合久久狠狠狠97色| 99久久免费国产精精品| 97婷婷大伊香蕉精品视频| 视频一区中文| 91小视频在线播放| 亚洲午夜精品在线| 九色视频在线观看免费播放| 91精品国产综合久久久久久蜜臀 | 日韩免费电影在线观看| 天天碰免费视频 | 日韩欧美在线观看免费| 色偷偷综合社区| www.国产精品一区| 男人的天堂日韩| 亚洲美女精品一区| 青青久草在线| 亚洲一区二区三区久久| 国产日韩欧美三区| 精品在线观看一区| 亚洲国产成人精品女人久久久 | 欧美怡红院视频| 男女免费观看在线爽爽爽视频| 日韩国产在线一区| 国产91富婆露脸刺激对白| 91青青草视频| 久久久久久这里只有精品| 不卡视频在线| 中文在线永久免费观看| 3751色影院一区二区三区| 忘忧草在线影院两性视频|