Maison  >  Questions et réponses  >  le corps du texte

java - Quel est le rôle de la méthode afterNodeInsertion dans HashMap?

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 ?

仅有的幸福仅有的幸福2712 Il y a quelques jours891

répondre à tous(1)je répondrai

  • 淡淡烟草味

    淡淡烟草味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. HashMapLinkedHashMap类服务的。

    LinkedHashMapHashMap 的一个子类,它保留插入的顺序,如果需要输出的顺序和输入时的相同,那么就选用 LinkedHashMap

    LinkedHashMap中被覆盖的afterNodeInsertion

    LinkedHashMap est une sous-classe de HashMap, 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 . 🎜
    🎜La méthode 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);
        }
    }

    répondre
    0
  • Annulerrépondre