八股文 | hashcode与equals
Java中的hashcode方法
哈希表(也叫散列表)是一种常用的数据结构,通常被用来提高查找效率。无论哈希表总中有多少条数据,插入和查找的时间复杂度都是为O(1)。
根据这个方法的声明可知,该方法返回一个int类型的数值,并且是(native)本地方法,因此在Object类中并没有给出具体的实现。
实际上哈希函数就是从键值到索引的过程,需要通过哈希函数来进行计算。
一. hashCode方法的作用
hashCode方法的主要作用是为了配合基于散列的集合一起正常运行,这样的散列集合包括HashSet、HashMap以及HashTable。
Java中的hashCode方法就是根据一定的规则将与对象相关的信息(比如对象的存储地址,对象的字段等)映射成一个数值,这个数值称作为散列值。
hashCode方法的存在是为了减少equals方法的调用次数,从而提高程序效率。
二. equals方法和hashCode方法
对于两个对象,如果调用equals方法得到的结果为true,则两个对象的hashcode值必定相等;
如果equals方法得到的结果为false,则两个对象的hashcode值不一定不同;
如果两个对象的hashcode值不等,则equals方法得到的结果必定为false;
如果两个对象的hashcode值相等,则equals方法得到的结果未知。
输出结果:
原因:
默认情况下,hashCode方法是将对象的存储地址进行映射。
p1指向的对象和 System.out.println(hashMap.get(new People("Jack", 12)));
这句中的new People("Jack", 12)
生成的是两个对象,它们的存储地址肯定不同。
所以,在重写equals方法的同时,必须重写hashCode方法。
- 在程序执行期间,只要equals方法的比较操作用到的信息没有被修改,那么对这同一个对象调用多次,hashCode方法必须始终如一地返回同一个整数。
- 如果两个对象根据equals方法比较是相等的,那么调用两个对象的hashCode方法必须返回相同的整数结果。
- 如果两个对象根据equals方法比较是不等的,则hashCode方法不一定得返回不同的整数。
- 设计hashCode方法和equals方法的时候,如果对象中的数据易变,则最好在equals方法和hashCode方法中不要依赖于该字段。
__EOF__

本文链接:https://www.cnblogs.com/zhangzizi/p/16053560.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下