作者:光头之祖_617 | 来源:互联网 | 2023-07-28 14:02
讲下equals和hashcode,他们为何必须一起重写?hashcode方法重写规则。-1、equals和hashCode(哈希码)是什么? 两个都是Object类的方法equ
1、equals 和 hashCode(哈希码) 是什么?
两个都是 Object 类的方法 equals 是通过比较两个对象的地址值,正常通过new创建的对象都是不相同的
hashCode 是通过将内存地址通过native方法转换成 Int 值来比较
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值同时判断并覆盖 !