当前位置: 首页 > news >正文

java八股文面试[java基础]—— hashCode 与 equals 区别 == 与 equals的区别

两个对象的hashCode()相同时,equals()相等吗?_两个对象的hashcode一样,equal一样么_不想当个程序员的博客-CSDN博客

equals():比较的是非基本类型的数据的引用地址(即内存地址)是否相同,但是对于重写equals方法的类型,比较的是对象内容是否相同。
hashCode():计算对象实例的哈希码,用于返回字符串的哈希码。其中哈希码使用散列表(也叫哈希表)存储的。但是因为哈希表存储的Hash散列值时可能存在有冲突的情况,因此,两个对象的equals()可能不同,虽然概率很低。
因此在比较两个对象是否相等的时候,单单比较两个对象的hashCode是否相等是不可以的。

 

 

 

  • hashCode()方法是获取一串整数,我们称之为哈希码。默认情况下,是Object类里面的一个native方法,由jvm实现,其作用是标识一个唯一的对象(注意:这个hash码在无锁状态下存储于对象头中)

 equals()方法是比较两个对象是否相等。默认情况下比较两个对象的在内存的地址值,和==等价。不过,我们一般都会重写这个方法来达到我们想要的对象相等的效果。
这两个方法一个标识唯一对象,一个标识对象内存地址,描述两个不同维度信息好像没有什么关系?
目前为止确实是这样,但是在Map实现类中,计算hash值的扰动函数是依赖hashcode,如果只重写equals的话,那么会导致相同对象的生成的key值不一样,具体现象如下:

 所以,需要重写一般重写equals的时候,都会要求重写hashCode方法,避免出现这样的bug。
总结:hashCode和equals没有什么关系,不过一般重写equals的时候会强制要求重写hashCode避免出bug。

原则

1.同一个对象(没有发生过修改)无论何时调用hashCode()得到的返回值必须一样。
如果一个key对象在put的时候调用hashCode()决定了存放的位置,而在get的时候调用hashCode()得到了不一样的返回值,这个值映射到了一个和原来不一样的地方,那么肯定就找不到原来那个键值对了。

2.hashCode()的返回值相等的对象不一定相等,通过hashCode()和equals()必须能唯一确定一个对象。不相等的对象的hashCode()的结果可以相等。hashCode()在注意关注碰撞问题的时候,也要关注生成速度问题,完美hash不现实。

3.一旦重写了equals()函数(重写equals的时候还要注意要满足自反性、对称性、传递性、一致性),就必须重写hashCode()函数。而且hashCode()的生成哈希值的依据应该是equals()中用来比较是否相等的字段。

如果两个由equals()规定相等的对象生成的hashCode不等,对于hashMap来说,他们很可能分别映射到不同位置,没有调用equals()比较是否相等的机会,两个实际上相等的对象可能被插入不同位置,出现错误。其他一些基于哈希方法的集合类可能也会有这个问题

String类 equals方法的定义 

 

知识点来源:

 【基础】==和equals_哔哩哔哩_bilibili
【2023年面试】hashcode和equals如何使用_哔哩哔哩_bilibilihttps://baijiahao.baidu.com/s?id=1732729842132154711&wfr=spider&for=pc面试高频:说说hashCode() 和 equals() 之间的关系? - 知乎

http://www.lryc.cn/news/139601.html

相关文章:

  • Dubbo之PojoUtils源码分析
  • 【C++】—— C++11新特性之 “右值引用和移动语义”
  • 谈一谈redis脑裂
  • 基于原生Servlet使用模板引擎Thymeleaf访问界面
  • 【C语言】15-函数-1
  • 08-信息收集-架构、搭建、WAF等
  • Qt --- 显示相关设置 窗口属性等
  • 使用小程序实现左侧菜单,右侧列表双向联动效果
  • selenium中处理验证码问题
  • EMR电子病历系统 SaaS电子病历编辑器源码 电子病历模板编辑器
  • 一些自定义hooks
  • 基于Citespace、vosviewer、R语言的文献计量学可视化分析技术及全流程文献可视化SCI论文高效写作方法
  • lEC 61068-2-14_2023环境试验.第2-14部分:试验.试验N:温度变化, 最新版发布
  • CFDEM学习笔记
  • SpringBoot入门篇1 - 简介和工程创建
  • MyBatis-Plus updateById不更新null值
  • 用pytorch实现AlexNet
  • LeetCode560.和为k的子数组
  • echarts 的dataZoom滑块两端文字被遮挡
  • MongoDB基本使用
  • C++ 中的左值(Lvalues)和右值(Rvalues)
  • html流光按钮
  • HAProxy+nginx搭建负载均衡群集
  • logback-spring.xml 的配置及详解(直接复制粘贴可用)
  • C语言易错点整理
  • 60.每日一练:回文数(力扣)
  • 算法通关村第5关【青铜】| Hash和队列的特征
  • C++:函数
  • Linux网络编程:libevent事件通知库
  • java.lang.reflect.InvocationTargetException:null报未知异常