Java|Java重写equals方法时为什么要重写hashCode方法
文章图片
【Java|Java重写equals方法时为什么要重写hashCode方法】
文章图片
文章图片
文章图片
文章图片
文章图片
文章图片
文章图片
在我们平时编写Java代码时 , 重写equals方法时一定要重写hashCode方法 , 这是为什么呢?
在讨论这个问题前 , 我们先看下Object类中hashCode方法和equals方法 。
hashCode方法:
翻译如下:
equals方法:
翻译如下:
1、hashCode方法的作用在Java中也一样 , hashCode方法的主要作用是为了配合基于散列的集合一起正常运行 , 这样的散列集合包括HashSet、HashMap以及HashTable 。
为什么这么说呢?考虑一种情况 , 当向集合中插入对象时 , 如何判别在集合中是否已经存在该对象了?
也许大多数人都会想到调用equals方法来逐个进行比较 , 这个方法确实可行 。 但是如果集合中已经存在一万条数据或者更多的数据 , 如果采用equals方法去逐一比较 , 效率必然是一个问题 。
此时hashCode方法的作用就体现出来了 , 当集合要添加新的对象时 , 先调用这个对象的hashCode方法 , 得到对应的hashcode值 , 实际上在HashMap的具体实现中会用一个table保存已经存进去的对象的hashcode值 , 如果table中没有该hashcode值 , 它就可以直接存进去 , 不用再进行任何比较了;如果存在该hashcode值 ,就调用它的equals方法与新元素进行比较 , 相同的话就不存了 , 不相同就散列其它的地址 , 所以这里存在一个冲突解决的问题 , 这样一来实际调用equals方法的次数就大大降低了 , 说通俗一点:Java中的hashCode方法就是根据一定的规则将与对象相关的信息(比如对象的存储地址 , 对象的字段等)映射成一个数值 , 这个数值称作为散列值 。
java.util.HashMap的中put方法的具体实现 , 先计算key的hash值 , 从table数组中取出对应节点 , 如果节点不存在则添加一个节点;如果存在则更新value , 返回旧value 。
hash方法会调用对象的hashCode()方法:
addEntry方法添加新节点:
new一个Entry实例 , next指向原有的Entry实例 。 也就是新new的Entry实例是该链表的头 。
推荐阅读
- Java|Java项目搜索功能的实现
- Java|面试三年经验的程序员,感觉简历在造假!连个简单的题目都不会
- 游龙战神|-启动流程,好程序员Java培训分享SpringBoot
- 移动互联网|干了两年 Java,自考本科,15k,很难有机会进大厂?
- Java|一份好的 Java 开发简历,让面试官眼前一亮,到底长啥样?
- 引领先锋|/ PPTX,Java工程师福利!1分钟学会使用Aspose.PDF将PDF转换为PPT
- 马维英|我只相信数字!Java, 大数据,Python哪个前景更好,薪资更高?
- Java|5个主流的Java开源IDE工具
- 小米科技|6月份最受欢迎编程语言:Python取代Java,Rust进入前20名
- mp4|清华毕业扫地僧,用157集终于把java给讲完了,总计3.13GB