国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

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

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

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

問題描述

環境:jdk1.8問題:學習HashMap的時候發現在putVal方法的最后調用了afterNodeInsertion方法

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

又去搜索一下afterNodeInsertion方法,發現不少地方都調用了它,但是它的實現卻是

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) { }

源碼中其實已經說了,這個三個方法都是為了繼承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
相關文章:
主站蜘蛛池模板: 共和县| 古交市| 南安市| 高密市| 商洛市| 民丰县| 疏附县| 泌阳县| 北票市| 郑州市| 淳安县| 慈溪市| 龙江县| 姜堰市| 林周县| 永胜县| 垫江县| 吉安市| 屏东县| 千阳县| 淮安市| 项城市| 铁岭市| 利川市| 梨树县| 洛隆县| 禹城市| 义马市| 内黄县| 洞头县| 拉萨市| 黔东| 余姚市| 道孚县| 屯门区| 镇康县| 清镇市| 镇巴县| 龙江县| 黔江区| 娄烦县|