久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

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

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

問題描述

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

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

又去搜索一下afterNodeInsertion方法,發(fā)現(xiàn)不少地方都調(diào)用了它,但是它的實現(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類服務(wù)的。

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

LinkedHashMap中被覆蓋的afterNodeInsertion方法,用來回調(diào)移除最早放入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); }}

標(biāo)簽: java
相關(guān)文章:
主站蜘蛛池模板: 明光市| 麦盖提县| 徐州市| 栾川县| 阿巴嘎旗| 右玉县| 垫江县| 山阳县| 贞丰县| 利辛县| 思茅市| 金华市| 高邑县| 福泉市| 北辰区| 梁山县| 宁远县| 陆丰市| 韶山市| 封丘县| 松桃| 阳西县| 凯里市| 什邡市| 亳州市| 洞口县| 广南县| 治多县| 香港 | 黄平县| 丹凤县| 定结县| 廉江市| 句容市| 东乡族自治县| 沾益县| 鄂托克前旗| 财经| 静乐县| 金湖县| 河津市|