java - HashMap中afterNodeInsertion方法有什么作用呢
問題描述
環(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); }}
相關文章:
1. python執(zhí)行cmd命令,怎么讓他執(zhí)行類似Ctrl+C效果將其結束命令?2. python - Flask寫的注冊頁面,當注冊時,如果填寫數(shù)據(jù)庫里有的相同數(shù)據(jù),就報錯3. python - Django有哪些成功項目?4. python - scrapy url去重5. 實現(xiàn)bing搜索工具urlAPI提交6. MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)7. mysql在限制條件下篩選某列數(shù)據(jù)相同的值8. 關于mysql聯(lián)合查詢一對多的顯示結果問題9. 數(shù)據(jù)庫 - Mysql的存儲過程真的是個坑!求助下面的存儲過程哪里錯啦,實在是找不到哪里的問題了。10. Python從URL中提取域名
