重写equals()方法就尽量重写hashcode()方法的原因

2024-03-09 17:18

本文主要是介绍重写equals()方法就尽量重写hashcode()方法的原因,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

equals方法与hashcode方法都是Object类中的方法。

我们就先来看一下这两个方法的源码:

在这里插入图片描述

在这里插入图片描述

如上面两张图所示,hashcode()是一个本地native方法,返回的是对象引用指向该对象的内存地址。

而equals()方法也比较的是两个对象的地址是否相同。


那么为什么我们重写equals()方法就要尽量重写hashcode()方法呢?

原因在hashcode()方法的文档注释中已经有了一个说明:

equals()方法返回值为false时,两个对象的hashcode()方法的返回值没有必要一定相等,但是建议重写hashcode()方法,当equals()方法返回false时,相比较的两个对象的hashcode值也不同,这样有利于提升hash表的性能。

Java中规定,如果equals为true,那么hashcode一定也是相同的。如果equals为true而hashcode不同,那么在HashMap的存储过程中就发生了悖论

用处

集合框架中

重写equals与hashcode方法,常用于集合框架中,判断集合中的数据是否存在。

可以具体看我的另外两篇博客:

  1. HashSet中的add()方法:
    https://blog.csdn.net/S_Tian/article/details/103009664
  2. ArrayList中的contains()方法:
    https://blog.csdn.net/S_Tian/article/details/102978060

String中

还有最常用的就是String类中重写了Object类中的equals与hashcode方法:

在这里插入图片描述
在这里插入图片描述

我们可以发现String类中的equals方法与hashcode方法,比较的都是字符串的内容是否相同,即String类中的char类型的数组value的值是否相同。

但是!:String类中会出现两个字符串调用equals方法为false,但hashcode相同的情况。

例如:
在这里插入图片描述
字符串a与b的hashCode取值是相同的,都是2112

因为ASCII码中 A对应Unicode码的65 a对应97,B对应66,根据hashcode()方法的算法:

Aa:31*65+97 = 2112
BB: 31*66+66 = 2112

就及极其凑巧

这篇关于重写equals()方法就尽量重写hashcode()方法的原因的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/791370

相关文章

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

如何将Python彻底卸载的三种方法

《如何将Python彻底卸载的三种方法》通常我们在一些软件的使用上有碰壁,第一反应就是卸载重装,所以有小伙伴就问我Python怎么卸载才能彻底卸载干净,今天这篇文章,小编就来教大家如何彻底卸载Pyth... 目录软件卸载①方法:②方法:③方法:清理相关文件夹软件卸载①方法:首先,在安装python时,下

电脑死机无反应怎么强制重启? 一文读懂方法及注意事项

《电脑死机无反应怎么强制重启?一文读懂方法及注意事项》在日常使用电脑的过程中,我们难免会遇到电脑无法正常启动的情况,本文将详细介绍几种常见的电脑强制开机方法,并探讨在强制开机后应注意的事项,以及如何... 在日常生活和工作中,我们经常会遇到电脑突然无反应的情况,这时候强制重启就成了解决问题的“救命稻草”。那

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

Python中的魔术方法__new__详解

《Python中的魔术方法__new__详解》:本文主要介绍Python中的魔术方法__new__的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、核心意义与机制1.1 构造过程原理1.2 与 __init__ 对比二、核心功能解析2.1 核心能力2.2

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

关于pandas的read_csv方法使用解读

《关于pandas的read_csv方法使用解读》:本文主要介绍关于pandas的read_csv方法使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录pandas的read_csv方法解读read_csv中的参数基本参数通用解析参数空值处理相关参数时间处理相关

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

Java中使用Hutool进行AES加密解密的方法举例

《Java中使用Hutool进行AES加密解密的方法举例》AES是一种对称加密,所谓对称加密就是加密与解密使用的秘钥是一个,下面:本文主要介绍Java中使用Hutool进行AES加密解密的相关资料... 目录前言一、Hutool简介与引入1.1 Hutool简介1.2 引入Hutool二、AES加密解密基础