gpt4 book ai didi

java - HashTable 碰撞 在哪里使用 LinkedList 来存储具有相同键的多个值

转载 作者:行者123 更新时间:2023-12-02 07:24:03 25 4
gpt4 key购买 nike

我读过很多次,在哈希表中,当发生冲突时,一个键与多个值存储在链接列表中,然后它会进行 equals 调用来检查哪些键映射到所需的值,但我看到哈希表的代码它没有任何put 方法或 get 方法中的链表代码。它使用 Entry[] 数组,我不明白如何将其用作链接列表。

for (Entry<K,V> e = tab[index] ; e != null ; e = e.next) {
if ((e.hash == hash) && e.key.equals(key)) {
V old = e.value;
e.value = value;
return old;
}
}

请指导并消除我的疑问。

最佳答案

我认为 JVM 之间的实现可能有所不同,但根据我的理解,使用了链表(但不是必需的 java.util.LinkedList)。这就是我使用的 JVM 中 HashTable 中“put”的实现方式:

public Object put(Object key, Object value) {
// Make sure the value is not null
if (value == null) throw new NullPointerException();

// Makes sure the key is not already in the hashtable.
HashtableEntry e;
HashtableEntry tab[] = table;
int hash = key.hashCode();
int index = (hash & 0x7FFFFFFF) % tab.length;

for (e = tab[index] ; e != null ; e = e.next) {
if ((e.hash == hash) && e.key.equals(key)) {
Object old = e.value;
e.value = value;
return old;
}
}

此版本与您发布的版本之间存在一些差异,但我认为它们背后的逻辑是相同的。HashtableEntry 看起来像这样:

class HashtableEntry {
int hash;
Object key;
Object value;
HashtableEntry next;
(...)

“HashtableEntry next”引用确实使 HashtableEntry 成为链表(链表是一种结构,其中每个元素都引用相同类型的另一个元素,除非它是列表中的最后一个元素)。我认为您正在寻找的是 java.util.LinkedList 但 HastTable 以自己的方式实现链表结构。

关于java - HashTable 碰撞 在哪里使用 LinkedList 来存储具有相同键的多个值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13779172/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com