重写equals()时为什么也得重写hashCode()之深度解读equals方法与hashCode方法渊源
2016-08-12 11:09
429 查看
重写equals()时为什么也得重写hashCode()之深度解读equals方法与hashCode方法渊源
在使用Map接口时,我们的愿望是当key1.equals(key2)时,它们获取的value是相同的,但是Map还会计算hashcode,如果不同,那么这两个键是不同,value也就不同,所以重写hachcode方法,以保证hashcode相同。
源代码:
在使用Map接口时,我们的愿望是当key1.equals(key2)时,它们获取的value是相同的,但是Map还会计算hashcode,如果不同,那么这两个键是不同,value也就不同,所以重写hachcode方法,以保证hashcode相同。
源代码:
public V get(Object key) { Node<K,V> e; return (e = getNode(hash(key), key)) == null ? null : e.value; }
final Node<K,V> getNode(int hash, Object key) { Node<K,V>[] tab; Node<K,V> first, e; int n; K k; if ((tab = table) != null && (n = tab.length) > 0 && (first = tab[(n - 1) & hash]) != null) { if (first.hash == hash && // always check first node ((k = first.key) == key || (key != null && key.equals(k)))) return first; if ((e = first.next) != null) { if (first instanceof TreeNode) return ((TreeNode<K,V>)first).getTreeNode(hash, key); do { if (e.hash == hash && ((k = e.key) == key || (key != null && key.equals(k)))) return e; } while ((e = e.next) != null); } } return null; }
相关文章推荐
- 重写equal()时为什么也得重写hashCode()之深度解读equal方法与hashCode方法渊源
- 重写equal()时为什么也得重写hashCode()之深度解读equal方法与hashCode方法渊源
- 重写equal()时为什么也得重写hashCode()之深度解读equal方法与hashCode方法渊源
- 重写equal()时为什么也得重写hashCode()之深度解读equal方法与hashCode方法渊源
- ID的生成策略(hibernate的id生成策略,主键类为什么需要实现序列化接口,同时还要重写hashCode()和equals()方法)
- hibernate中的po类为什么要重写equals和hashcode方法的对话
- 整理 Object 类(为什么重写 equals 和 hashCode 方法)
- 重写equals方法时为什么需要重写hashCode方法
- 为什么重写equals方法,一定要重写HashCode方法?
- JAVA中重写equals()方法为什么要重写hashcode()方法?
- JAVA中重写equals()方法为什么要重写hashcode()方法说明
- 为什么重写equals方法,一定要重写HashCode方法?(
- 为什么要重写hashcode和equals方法
- JAVA中重写equals()方法为什么要重写hashcode()方法?
- Hibernate为什么要重写equals和hashCode方法
- Hibernate为什么要重写equals和hashCode方法
- HashCode的作用 以及重写equals方法为什么要重写HashCode方法?
- 【Java基础】JAVA中重写equals()方法为什么要重写hashcode()方法?
- JAVA中重写equals()方法为什么要重写hashcode()方法?
- 为什么要重写equals和hashcode方法