日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

HashMap源码分析1:添加元素

發(fā)布時間:2025/5/22 编程问答 78 豆豆
生活随笔 收集整理的這篇文章主要介紹了 HashMap源码分析1:添加元素 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本文源碼基于JDK1.8.0_45。?

?

1 final V putVal(int hash, K key, V value, boolean onlyIfAbsent, boolean evict) { 2 Node<K,V>[] tab; Node<K,V> p; int n, i; 3 //延遲初始化數組,這是HashMap中最基礎的數據結構 4 if ((tab = table) == null || (n = tab.length) == 0) 5 n = (tab = resize()).length; 6 //數組中hash對應位置沒有元素,就把當前元素放入作為頭節(jié)點,結束put的流程 7 //計算哈希值在數組中的位置時,使用了數組容量-1與哈希值做與運算的方式,保留了哈希值的低位數據作為數組下標 8 if ((p = tab[i = (n - 1) & hash]) == null) 9 tab[i] = newNode(hash, key, value, null); 10 else { 11 Node<K,V> e; K k; 12 //如果頭節(jié)點的Key值相等,則頭節(jié)點是目標元素 13 if (p.hash == hash && 14 ((k = p.key) == key || (key != null && key.equals(k)))) 15 e = p; 16 //如果頭節(jié)點是一個樹節(jié)點,表示該數據結構是紅黑樹,則調用紅黑樹的方法查找或添加目標元素 17 else if (p instanceof TreeNode) 18 e = ((TreeNode<K,V>)p).putTreeVal(this, tab, hash, key, value); 19 //最后判斷該數據結構為鏈表,并在鏈表中查找Key相等的元素 20 else { 21 for (int binCount = 0; ; ++binCount) { 22 //鏈表中不存在該Key值,將新值添加到鏈表末端,如果鏈表長度達到閾值需要轉換為紅黑樹 23 //treeifyBin方法中生成紅黑樹有一個條件,如果數組長度太小,只會先執(zhí)行擴容操作,當數組長度達到生成樹的閾值時才會執(zhí)行生成紅黑樹的邏輯 24 if ((e = p.next) == null) { 25 p.next = newNode(hash, key, value, null); 26 if (binCount >= TREEIFY_THRESHOLD - 1) // -1 for 1st 27 treeifyBin(tab, hash); 28 break; 29 } 30 //如果在鏈表中找到目標節(jié)點,則中斷循環(huán) 31 if (e.hash == hash && 32 ((k = e.key) == key || (key != null && key.equals(k)))) 33 break; 34 p = e; 35 } 36 } 37 //如果HashMap中不存在目標元素,前面的代碼邏輯已經將元素添加進了Map中 38 //如果HashMap中存在目標元素,則視情況選擇是否更新舊的值 39 if (e != null) { // existing mapping for key 40 V oldValue = e.value; 41 if (!onlyIfAbsent || oldValue == null) 42 e.value = value; 43 afterNodeAccess(e); 44 return oldValue; 45 } 46 } 47 /** 48 * 如果新增了節(jié)點,最后還需要更新節(jié)點的數量,如果超過閾值則需要對HashMap進行數組擴容,并重新分配節(jié)點所在的數組 49 * 擴容的原因在于數組的長度一定,當元素的哈希值碰撞時,會以鏈表或紅黑樹的形式存儲,元素的數量太多會影響HashMap的讀寫效率 50 * 因此需要對數組進行擴容,使元素更加分散,減少鏈表的長度或紅黑樹的高度。 51 */ 52 ++modCount; 53 if (++size > threshold) 54 resize(); 55 afterNodeInsertion(evict); 56 return null; 57 }

?

代碼中涉及的resize方法、紅黑樹的實現、鏈表轉換成紅黑樹的邏輯等將在系列其他文章介紹。

轉載于:https://www.cnblogs.com/lwpimis/p/10572235.html

《新程序員》:云原生和全面數字化實踐50位技術專家共同創(chuàng)作,文字、視頻、音頻交互閱讀

總結

以上是生活随笔為你收集整理的HashMap源码分析1:添加元素的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。