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

歡迎訪(fǎng)問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

JDK源码学习04-寄生虫LinkedHashMap

發(fā)布時(shí)間:2024/3/24 编程问答 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JDK源码学习04-寄生虫LinkedHashMap 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

活久見(jiàn)的LinkedHashMap

隨便聊聊

筆者大三,在2021.1.18入職字節(jié)實(shí)習(xí)生,干了四十天就休假跑路回去上課了。最近一大段時(shí)間過(guò)的非常松懈,現(xiàn)在報(bào)復(fù)性瘋狂發(fā)布博客,哈哈。還是決定閱讀JDK源碼,從集合開(kāi)始,希望能夠讀完核心的集合、AQS、線(xiàn)程池在等部分,最近對(duì)Java并發(fā)比較感興趣也比較有體會(huì),鬼知道能不能堅(jiān)持到那個(gè)時(shí)候。筆者的文章可能不夠詳細(xì),但會(huì)記錄下來(lái)個(gè)人覺(jué)得比較核心的內(nèi)容。
聯(lián)系方式:qq 754647431

LinkedHashMap簡(jiǎn)介

核心原理:

LinkedHashMap的底層結(jié)構(gòu)是:由于繼承而產(chǎn)生的HashMap父類(lèi)|LinkedHashMap自己的雙向鏈表
所以L(fǎng)inkedHashMap只不過(guò)是在HashMap的基礎(chǔ)上額外維護(hù)了一個(gè)雙向鏈表罷了,僅此而已
那么問(wèn)題來(lái)了:LinkedHashMap是如何在自己實(shí)現(xiàn)一點(diǎn)點(diǎn)方法的基礎(chǔ)上,利用到HashMap中呢?
-----實(shí)際上是LinkedHashMap重寫(xiě)了HashMap的newNode函數(shù),額外添加了一句話(huà)linkNodeLast§;這樣就實(shí)現(xiàn)了在插入時(shí)維護(hù)雙向鏈表,但是刪除元素非常復(fù)雜,需要仔細(xì)看源碼才行。這里先放下HashMap留給LinkedHashMap的后門(mén)方法。

# 這是HashMap留給LinkedHashMap的后門(mén),// Callbacks to allow LinkedHashMap post-actions// 如果hashmap的節(jié)點(diǎn)被更新 則調(diào)用該方法void afterNodeAccess(Node<K,V> p) { }// 如果hashmap插入節(jié)點(diǎn) 則調(diào)用該方法void afterNodeInsertion(boolean evict) { }// 如果hashmap刪除節(jié)點(diǎn) 則調(diào)用該方法void afterNodeRemoval(Node<K,V> p) { }

這是我調(diào)試的時(shí)候截的圖,可以看出,LinkedHashMap按順序存儲(chǔ)了雙向鏈表結(jié)構(gòu),而HashMap也按hash存儲(chǔ)了數(shù)據(jù),每個(gè)數(shù)據(jù)都被存儲(chǔ)了兩次,并且結(jié)構(gòu)體也不同

  • 我們可以發(fā)現(xiàn)LinkedHashMap繼承于HashMap,在HashMap已經(jīng)實(shí)現(xiàn)Map接口的情況下,LinkedHashMap仍然實(shí)現(xiàn)了Map接口,實(shí)現(xiàn)Map接口會(huì)要求LinkedHashMap實(shí)現(xiàn)所有Map接口的方法。
  • public class LinkedHashMap<K,V>extends HashMap<K,V>implements Map<K,V>
  • 我們可以發(fā)現(xiàn),LinkedHashMap包含的函數(shù)非常少,甚至不包含put方法,這是因?yàn)長(zhǎng)inkedHashMap繼承了HashMap的put等方法。
  • 我們來(lái)看看LinkedHashMap如何從HashMap獲取數(shù)據(jù),來(lái)維護(hù)自己的雙向鏈表。
    • LinkedHashMap重寫(xiě)了HashMap的newNode方法,每次HashMap需要插入節(jié)點(diǎn)的時(shí)候都需要newNode函數(shù),這樣LinkedHashMap就能夠通過(guò)linkNodeLast§;來(lái)維護(hù)雙向鏈表了。
    Node<K,V> newNode(int hash, K key, V value, Node<K,V> e) {LinkedHashMap.Entry<K,V> p =new LinkedHashMap.Entry<K,V>(hash, key, value, e);linkNodeLast(p);return p;}

    核心維護(hù)雙向鏈表的函數(shù)

    // link at the end of listprivate void linkNodeLast(LinkedHashMap.Entry<K,V> p) {// 獲取雙向鏈表尾節(jié)點(diǎn) 用來(lái)實(shí)現(xiàn)尾插LinkedHashMap.Entry<K,V> last = tail;// 尾節(jié)點(diǎn)指向新節(jié)點(diǎn)tail = p;// 如果雙向鏈表尾空 設(shè)置頭節(jié)點(diǎn)指向新節(jié)點(diǎn) 此時(shí)頭尾都指向新節(jié)點(diǎn)if (last == null)head = p;else {// 原尾節(jié)點(diǎn)與新節(jié)點(diǎn)雙向奔赴p.before = last;last.after = p;}}

    總結(jié)

    以上是生活随笔為你收集整理的JDK源码学习04-寄生虫LinkedHashMap的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 亚洲国产精品va在线 | ww成人| 黄色福利在线观看 | 榴莲视频黄色 | 午夜精品久久久久久99热 | 91香蕉视频在线观看免费 | 2020亚洲男人天堂 | 好吊一区二区三区视频 | 黄色国产视频 | 国产黄在线观看 | 免费在线不卡av | 天堂资源在线播放 | 老牛影视一区二区三区 | 免费久久网站 | 丰满人妻一区二区三区大胸 | 蜜桃无码一区二区三区 | 泰国午夜理伦三级 | 亚洲三级影视 | 伊人免费视频二 | 午夜一二区 | 中文字幕在线播放不卡 | 男女日日 | 综合在线亚洲 | 日韩欧美日本 | 性高潮久久久久久 | 五月天福利视频 | 国产精品久久久久久无人区 | 玖玖爱在线精品视频 | 哺乳期av | 精品国产伦一区 | 久操视频在线观看免费 | 黑丝美女一区二区 | 欧美女优在线 | 女同久久另类69精品国产 | wwww日本60 | 操女人逼逼视频 | 成年网站 | 亚洲欧美日韩一区二区三区四区 | 短视频在线观看 | 国产成人在线视频免费观看 | 日本熟妇毛茸茸丰满 | 91香蕉视频污污 | 日批在线播放 | 国产高清免费视频 | 日韩精品一| 麻豆tv在线| 国产精品久久久久久av | 婷婷六月丁| 日女人免费视频 | 久久久久国产精品一区二区 | 粗大的内捧猛烈进出在线视频 | 91av爱爱| av中文资源在线 | 中文字幕av解说 | 日本三级吃奶头添泬无码苍井空 | 欧美bbbbbbbbbbbb18av | 伊人性视频 | 欧美日在线 | 欧美成年人视频 | 另类视频一区 | 亚洲精品一区二三区 | 久久久久久香蕉 | 日韩欧美字幕 | 亚洲在线第一页 | 成人精品网 | 免费观看a视频 | 97人妻精品一区二区三区动漫 | 91老女人| 狗爬女子的视频 | 一边顶弄一边接吻 | 免费播放片大片 | 欧美国产一二三区 | 国产精品熟女视频 | 亚洲系列第一页 | 欧美xxxxx精品 | 污网站免费在线观看 | 操操操操操操操 | 亚洲成人激情在线 | 亚洲欧洲综合在线 | 日本人三级 | 精品视频第一页 | 日韩精品免费看 | 欧美精品一区二区三 | 91精品久久久久久久 | 好男人www社区 | 国产三级做爰高清在线 | 91在线资源 | 国产一区二区免费 | 91精品婷婷国产综合久久竹菊 | 午夜精品久久久久久久久久久久 | 欧美性免费 | 超碰青草| 想要视频在线观看 | 国产欧美视频一区二区三区 | 豆花视频在线播放 | 色婷婷av久久久久久久 | 国产在线自 | 久久精品亚洲一区 | 在线观看网址你懂的 |