【问题标题】:Use of recordAccess(this) in Entry<K, V> class在 Entry<K, V> 类中使用 recordAccess(this)
【发布时间】:2013-07-16 05:38:35
【问题描述】:

在查看 HashMap 类时,我遇到了这个方法:-

    /**
     * This method is invoked whenever the value in an entry is
     * overwritten by an invocation of put(k,v) for a key k that's already
     * in the HashMap.
     */
    void recordAccess(HashMap<K,V> m) {
    }

其实这个方法是在Entry&lt;K, V&gt;的内部类里面定义的

我无法理解该评论。这个方法有什么作用?

PS : 我还可以看到这个方法在 HashMap 的 putForNullKey() 方法中被调用

 private V putForNullKey(V value) {
        for (Entry<K,V> e = table[0]; e != null; e = e.next) {
            if (e.key == null) {
                V oldValue = e.value;
                e.value = value;
                e.recordAccess(this); // call
                return oldValue;
            }
        }
        modCount++;
        addEntry(0, null, value, 0);
        return null;
    }

更新:我已经更新了第一个代码 sn-p。

【问题讨论】:

    标签: java collections hashmap hashtable


    【解决方案1】:

    LinkedHashMap 可以有两种顺序:插入顺序或访问顺序。如果使用访问顺序,则此方法确保将访问的条目移动到列表的开头。

    【讨论】:

    • 您能详细说明一下吗?为什么会从 HashMap 的方法内部调用?
    • 这是一个实现细节。为了使 HashMap 和 LinkedHashMap 之间的代码相互化,基础 Map.Entry 定义了这个方法(默认情况下什么都不做),HashMap 调用它。在 LinkedHashMap 中,该方法被重写以维护访问顺序。
    • 检查我的编辑。 recordAccess() 是 HashMap 的 Entry 内部类中的无操作方法。
    • 这就是我刚才所说的。默认情况下,在 HashMap 中,它什么也不做。它在 LinkedHashMap 中被覆盖以维护访问顺序。 LinkedHashMap几乎所有的代码都在HashMap中,而这个方法的存在只是因为LinkedHashMap需要它。
    猜你喜欢
    • 1970-01-01
    • 2019-10-10
    • 1970-01-01
    • 2018-10-07
    • 2016-11-07
    • 2021-06-17
    • 2012-03-31
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多