0

0

在Java中为什么要重写equals和hashCode_equals与hashCode设计规范解析

P粉602998670

P粉602998670

发布时间:2025-12-31 17:04:46

|

820人浏览过

|

来源于php中文网

原创

必须重写equals和hashcode以保证逻辑相等对象在hashmap等集合中行为一致:若equals为true则hashcode必相同;二者需遵守自反性、对称性、传递性、一致性及null处理约定,且字段选择须合理。

在java中为什么要重写equals和hashcode_equals与hashcode设计规范解析

在Java中重写 equalshashCode,核心原因只有一个:**保证对象逻辑相等时,行为一致且能正确工作于基于哈希的集合(如 HashMapHashSet)中**。不重写,或重写不合规,会导致“明明两个对象内容一样,却查不到”“同一个对象存了两份”等诡异问题。

equals 与 hashCode 必须保持一致性

这是最根本的设计契约:如果两个对象通过 equals 判断为 true,那么它们的 hashCode 值必须相同;反之则不要求(不同对象可以有相同哈希值,即哈希碰撞)。JDK 的集合类(如 HashMap)正是依赖这一约定工作的:先用 hashCode 快速定位桶位置,再用 equals 精确比对键值。

  • 只重写 equals 不重写 hashCode → 逻辑相等的对象可能被散列到不同桶,get()contains() 失败
  • 只重写 hashCode 不重写 equals → 即使哈希值相同,equals 默认比较引用,仍判为不等,集合操作仍出错
  • 两者都重写但逻辑不一致(例如 equals 比较 name+age,hashCode 只用 name 计算)→ 违反契约,行为不可预测

重写 equals 要遵守五项基本约定

equals 方法不是随便写的,它必须满足自反性、对称性、传递性、一致性,以及对 null 的处理。违反任一约定,可能引发 HashSet 重复、TreeSet 异常、甚至并发场景下死循环等严重问题。

  • 自反性:对任意非 null 引用 xx.equals(x) 必须返回 true
  • 对称性:若 x.equals(y)true,则 y.equals(x) 也必须为 true
  • 传递性:若 x.equals(y)y.equals(z)true,则 x.equals(z) 必须为 true
  • 一致性:多次调用结果不变(前提是没有修改影响比较的字段)
  • 对 null 的处理:对任意非 null 引用 xx.equals(null) 必须返回 false

实践中,推荐使用 Objects.equals(a, b) 安全比较字段,避免空指针;用 instanceof + 类型强转做类型检查,而非 getClass() == obj.getClass()(除非明确要求严格类型限制)。

拍我AI
拍我AI

AI视频生成平台PixVerse的国内版本

下载

立即学习Java免费学习笔记(深入)”;

hashCode 的实现要兼顾分布性与确定性

hashCode 不必唯一,但应尽量让逻辑不同的对象产生不同哈希值(减少碰撞),更重要的是:只要参与比较的字段没变,多次调用必须返回相同值。常见写法是使用 Objects.hash(field1, field2, ...),它自动处理 null 并组合字段哈希。

  • 不要在 hashCode 中使用可变字段(如普通 setter 修改的属性),否则对象加入 HashSet 后再修改字段,就再也找不到了
  • 不要用随机数、当前时间、内存地址等不确定值参与计算
  • 若类是不可变的(如 String、自定义的 Point),用所有关键字段参与哈希计算最稳妥

IDE 和 Lombok 可以帮你生成,但得懂原理

IntelliJ 或 Eclipse 都支持自动生成 equalshashCode 方法,Lombok 的 @EqualsAndHashCode 更是只需一行注解。但生成只是起点——你仍需确认:选了哪些字段?是否包含父类字段?是否忽略某些业务上不该参与比较的字段(如数据库主键 ID、创建时间)?

  • 默认生成通常包含所有非静态字段,可能过度(比如含临时缓存字段)
  • 若继承自某个父类,且父类已重写 equals/hashCode,子类生成时应调用 super.equals()super.hashCode()
  • Lombok 的 callSuper = trueexclude = {"id"} 等参数要按需配置

不复杂但容易忽略。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
eclipse教程
eclipse教程

php中文网为大家带来eclipse教程合集,eclipse是一个开放源代码的、基于Java的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。php中文网还为大家带来eclipse的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

194

2023.06.14

eclipse怎么设置中文
eclipse怎么设置中文

eclipse设置中文的方法:除了设置界面为中文外,你还可以为Eclipse添加中文插件,以便更好地支持中文编程。例如,你可以安装EBNF插件来支持中文变量名,或安装Chinese Helper来提供中文帮助文档。本专题为大家提供eclipse设置中文相关的各种文章、以及下载和课程。

807

2023.07.24

c语言编程软件有哪些
c语言编程软件有哪些

c语言编程软件有GCC、Clang、Microsoft Visual Studio、Eclipse、NetBeans、Dev-C++、Code::Blocks、KDevelop、Sublime Text和Atom。更多关于c语言编程软件的问题详情请看本专题的文章。php中文网欢迎大家前来学习。

623

2023.11.02

Eclipse版本号有哪些区别
Eclipse版本号有哪些区别

区别:1、Eclipse 3.x系列:Eclipse的早期版本,包括3.0、3.1、3.2等;2、Eclipse 4.x系列:Eclipse的最新版本,包括4.0、4.1、4.2等;3、Eclipse IDE for Java Developers等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

180

2024.02.23

eclipse和idea有什么区别
eclipse和idea有什么区别

eclipse和idea的区别:1、平台支持;2、内存占用;3、插件系统;4、智能代码提示;5、界面设计;6、调试功能;7、学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

152

2024.02.23

eclipse设置中文全教程
eclipse设置中文全教程

本专题整合了eclipse设置中文相关教程,阅读专题下面的文章了解更多详细操作。

116

2025.10.10

eclipse字体放大教程
eclipse字体放大教程

本专题整合了eclipse字体放大教程,阅读专题下面的文章了解更多详细内容。

154

2025.10.10

eclipse左边栏不见了解决方法
eclipse左边栏不见了解决方法

本专题整合了eclipse左边栏相关教程,阅读专题下面的文章了解更多详细内容。

120

2025.10.15

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.3万人学习

C# 教程
C# 教程

共94课时 | 11.1万人学习

Java 教程
Java 教程

共578课时 | 80.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号