Maison > Questions et réponses > le corps du texte
Environnement : jdk1.8
Problème : lors de l'apprentissage de HashMap, j'ai découvert que la méthode afterNodeInsertion était appelée à la fin de la méthode putVal
...
++modCount;
if (++size > threshold)
resize();
afterNodeInsertion(evict);
return null;
J'ai recherché à nouveau la méthode afterNodeInsertion et j'ai découvert qu'elle est appelée à de nombreux endroits, mais son implémentation est
void afterNodeInsertion(boolean evict) { }
Une méthode vide ? ? Vous voulez savoir à quoi sert cette méthode ?
淡淡烟草味2017-05-17 10:05:41
// Callbacks to allow LinkedHashMap post-actions
void afterNodeAccess(Node<K,V> p) { }
void afterNodeInsertion(boolean evict) { }
void afterNodeRemoval(Node<K,V> p) { }
En fait, il a été mentionné dans le code source que ces trois méthodes servent toutes à hériter du service de classe LinkedHashMap
de HashMap
. HashMap
的LinkedHashMap
类服务的。
LinkedHashMap
是HashMap
的一个子类,它保留插入的顺序,如果需要输出的顺序和输入时的相同,那么就选用LinkedHashMap
。
LinkedHashMap
中被覆盖的afterNodeInsertion
🎜La méthodeLinkedHashMap
est une sous-classe deHashMap
, qui conserve l'ordre d'insertion. Si l'ordre de sortie doit être le même que l'ordre d'entrée, alors utilisez.LinkedHashMap
. 🎜
afterNodeInsertion
remplacée dans LinkedHashMap
est utilisée pour rappeler et supprimer le premier objet placé dans la carte🎜
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);
}
}