热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

讲下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值同时判断并覆盖 !


推荐阅读
author-avatar
光头之祖_617
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有