java - HashMap中afterNodeInsertion方法有什么作用呢
問題描述
環境: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); }}
相關文章:
1. css - 如何把一個視圖放在左浮動定位的視圖的上面?2. javascript - axios請求回來的數據組件無法進行綁定渲染3. php多任務倒計時求助4. python的正則怎么同時匹配兩個不同結果?5. javascript - vue中怎么使用原生js插件6. javascript - 請問下面代碼中的...是擴展運算符還是操作運算符?這樣寫是什么意思?7. javascript - 小demo:請教怎么做出類似于水滴不斷擴張的效果?8. css - 子元素跑到父元素外面9. MySQL的聯合查詢[union]有什么實際的用處10. javascript - jquery怎么讓a標簽跳轉后保持tab的樣式
