av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

java - HashMap中afterNodeInsertion方法有什么作用呢

瀏覽:115日期:2023-12-08 11:00:55

問題描述

環(huán)境:jdk1.8問題:學習HashMap的時候發(fā)現(xiàn)在putVal方法的最后調用了afterNodeInsertion方法

... ++modCount; if (++size > threshold)resize(); afterNodeInsertion(evict); return null;

又去搜索一下afterNodeInsertion方法,發(fā)現(xiàn)不少地方都調用了它,但是它的實現(xiàn)卻是

void afterNodeInsertion(boolean evict) { }

一個空方法??想知道這個方法到底有什么作用呢?

問題解答

回答1:

// Callbacks to allow LinkedHashMap post-actionsvoid afterNodeAccess(Node<K,V> p) { }void afterNodeInsertion(boolean evict) { }void afterNodeRemoval(Node<K,V> p) { }

源碼中其實已經(jīng)說了,這個三個方法都是為了繼承HashMap的LinkedHashMap類服務的。

LinkedHashMap 是 HashMap 的一個子類,它保留插入的順序,如果需要輸出的順序和輸入時的相同,那么就選用 LinkedHashMap。

LinkedHashMap中被覆蓋的afterNodeInsertion方法,用來回調移除最早放入Map的對象

void afterNodeInsertion(boolean evict) { // possibly remove eldest LinkedHashMap.Entry<K,V> first; if (evict && (first = head) != null && removeEldestEntry(first)) {K key = first.key;removeNode(hash(key), key, null, false, true); }}

標簽: java
相關文章:
主站蜘蛛池模板: 国产精品入口麻豆www | 国产精品久久久久久久久久 | 日本a视频| 亚洲精品在线免费看 | 国产精品日日夜夜 | 一区欧美 | 免费成人高清在线视频 | 草久久| 久久久www成人免费无遮挡大片 | 亚洲精品在线观 | 国产婷婷精品 | 亚洲免费一区二区 | 亚洲精品一二三区 | 欧美精品一区三区 | 国产精品久久久久aaaa九色 | 91在线电影| 亚洲系列第一页 | 理论片免费在线观看 | 精品国产精品一区二区夜夜嗨 | 欧美精品日韩精品 | 国产精品久久久久久久久久三级 | 91精品国产91久久久久久三级 | 日韩久久久一区二区 | 亚洲成人免费在线观看 | 精品视频在线观看 | 亚洲国产精品日韩av不卡在线 | 亚洲一区二区三区四区在线观看 | 国产一区二区在线视频 | 视频在线一区二区 | 国产精品视频在线播放 | av大片在线观看 | 毛片一区二区 | 国产中文字幕在线 | 成人免费小视频 | 国产一区不卡 | 一级黄色毛片免费 | 91精品久久久久久久 | 国产精品欧美一区二区三区 | 九九热免费看 | 成人免费视频播放 | 欧洲免费毛片 |