讲下equals和hashcode,他们为何必须一起重写?hashcode方法重写规则。

2,797 阅读2分钟

1、equals 和 hashCode(哈希码) 是什么?

 两个都是 Object 类的方法 equals 是通过比较两个对象的地址值,正常通过new创建的对象都是不相同的

image.png

hashCode 是通过将内存地址通过native方法转换成 Int 值来比较

image.png

2.使用环境:equals 方法是比较两个对象的内容,hashcode 方法只可能会在集合中用到 

3.hashCode 重写规则是什么?

 两个对象相等,hashCode 一定相等 

 两个对象不等,hashCode 不一定不等

 hashCode 相等,两个对象不一定相等

 hashCode 不等,两个对象一定不等

 4.只重写 equals 会怎样呢?

 如果需要大量并快速对比对象的话,equals 效率太低了。 这种容器一般为:hashset、hashmap、hashtable等,如:hashset 要求对象不能重复,内部肯定会对每个对象进行比较,所以根据对比规则,如果 hashCode 相同,在用 equals 验证,如果 hashCode 不同,则不同,这样就提高了效率 

 5.只重写 hashCode 会怎样呢? 

 只重写 hashCode 是不可靠,有时候两个对象生成的 hashCode 可能会一样,会出现特殊情况。 equal() 相等的两个对象他们的 hashCode() 肯定相等,也就是用 equal() 对比是绝对可靠的, hashCode() 相等的两个对象他们的 equal() 不一定相等,也就是 hashCode() 不是绝对可靠的 

 6.为什么在重写equals方法的时候要重写hashcode的方法? 

 在Java中的一些容器中,不允许有两个完全相同的对象,插入的时候,如果判断相同则会进行覆盖。这时候如果只重写了equals()的方法,而不重写hashcode的方法,Object中hashcode是根据对象的存储地址转换而形成的一个哈希值。这时候就有可能因为没有重写hashcode方法,造成相同的对象散列到不同的位置而造成对象的不能覆盖的问题。 

例如hashtable中覆盖是根据hash值和key的equals值同时判断并覆盖 !

image.png