Java hashmap中entry类中的hashcode和equals是什么
我可以看到java中Hashmap中的静态条目类有Equals和Hashcode方法。这些方法的用途是什么。put,get方法我们使用对象Hashcode和Equals方法Java hashmap中entry类中的hashcode和equals是什么,java,hashmap,Java,Hashmap,我可以看到java中Hashmap中的静态条目类有Equals和Hashcode方法。这些方法的用途是什么。put,get方法我们使用对象Hashcode和Equals方法 static class Entry<K,V> implements Map.Entry<K,V> { final K key; V value; Entry<K,V> next; final int hash; /** * Create
static class Entry<K,V> implements Map.Entry<K,V> {
final K key;
V value;
Entry<K,V> next;
final int hash;
/**
* Creates new entry.
*/
Entry(int h, K k, V v, Entry<K,V> n) {
value = v;
next = n;
key = k;
hash = h;
}
public final boolean equals(Object o) {
if (!(o instanceof Map.Entry))
return false;
Map.Entry e = (Map.Entry)o;
Object k1 = getKey();
Object k2 = e.getKey();
if (k1 == k2 || (k1 != null && k1.equals(k2))) {
Object v1 = getValue();
Object v2 = e.getValue();
if (v1 == v2 || (v1 != null && v1.equals(v2)))
return true;
}
return false;
}
public final int hashCode() {
return (key==null ? 0 : key.hashCode()) ^
(value==null ? 0 : value.hashCode());
}
public final String toString() {
return getKey() + "=" + getValue();
}
静态类条目实现Map.Entry{
最终K键;
V值;
进入下一步;
最终整数散列;
/**
*创建新条目。
*/
入口(入口h、入口K、入口V、入口n){
值=v;
next=n;
key=k;
hash=h;
}
公共最终布尔等于(对象o){
如果(!(映射项的实例))
返回false;
Map.Entry e=(Map.Entry)o;
对象k1=getKey();
对象k2=e.getKey();
如果(k1==k2 | |(k1!=null&&k1.equals(k2))){
对象v1=getValue();
对象v2=e.getValue();
如果(v1==v2 | |(v1!=null&&v1.equals(v2)))
返回true;
}
返回false;
}
公共最终int hashCode(){
返回(key==null?0:key.hashCode())^
(value==null?0:value.hashCode());
}
公共最终字符串toString(){
返回getKey()+“=”+getValue();
}
映射。Entry
表示映射中的键值对。所有这些方法都可以用于比较键值对,而不是比较键对象。映射。Entry
表示映射中的键值对。所有这些方法都可以用于比较键值对,而不是比较键对象s、 条目
es也是对象,完全可以比较它们是否相等,或者将它们用作地图中的键
此外,它们有时被用作穷人的
对类:,对于这种用途,您确实希望这些equals
和hashCode
的实现也是对象,完全可以比较它们是否相等,或者将它们用作映射中的键
此外,它们有时被用作穷人的对类:,在这种情况下,您真的需要这些等于和hashCode
的实现,这段代码不是来自Java的Hashtable
实现吗(与HashMap
相反,它是Java HashMap类,而不是Java的Hashtable
实现中的代码(与HashMap
相反,它是Java HashMap类。)