Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Object.hashCode() 详解

Object.hashCode() 详解

作者头像
修己xj
发布于 2023-12-26 08:25:18
发布于 2023-12-26 08:25:18
39500
代码可运行
举报
文章被收录于专栏:修己xj修己xj
运行总次数:0
代码可运行

Java编程中,hashCode方法是一个常见而重要的概念。它通常用于哈希表、集合以及一些需要高效检索数据的数据结构中。然而,对于许多开发者来说,hashCode方法可能是一个容易被忽略或者被简单实现的部分。在本文中,我们将深入探讨Java中hashCode的一些思考,以便更好地理解其背后的原理和影响。

hashcode.jpg

hashCode的简介

hashCode 返回的 "散列码" 是指通过哈希算法生成的一个整数,用于标识对象的唯一性。在Java中,hashCode方法被设计用来支持基于哈希的集合类,如HashMap、HashSet等,以及其他需要快速检索数据的数据结构。

hashCode的意义

  • 快速检索

散列码的主要作用是提高数据结构的检索效率。在哈希表中,通过散列码可以迅速定位到存储数据的位置,而不需要遍历整个数据集。这对于大规模数据集的快速检索非常重要,能够使得检索操作的时间复杂度接近常数级别。

  • 哈希集合性能

在使用哈希集合(如HashSet)时,散列码决定了元素在集合中的存储位置。如果不同的对象具有相同的散列码,就会发生哈希冲突,需要通过其他手段解决,如链地址法或开放寻址法。因此,好的散列码设计能够最小化哈希冲突,提高哈希集合的性能。

  • equals方法辅助

hashCode方法与equals方法是相关联的。在Java中,根据对象相等性的定义,如果两个对象相等(equals方法返回true),那么它们的散列码应该相等。这一关系有助于在哈希集合中正确地比较和存储对象。

  • 分布均匀

散列码的设计应尽量使得不同的对象生成不同的散列码,以减少哈希冲突的可能性。这需要考虑到对象的各个属性,确保它们都对最终的散列码有贡献,避免简单地依赖于某一个属性。

重写 hashCode 方法

为什么要重写 hashCode 方法

Object类中提供的默认实现是与当前线程有关的随机数和其他三个固定值进行xorshift运算后的结果数。这种默认实现在实际应用中可能并不总是满足需要,特别是当我们需要基于对象的内容来计算哈希码时。

源码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public native int hashCode();

如何重写hashCode方法

在自定义类中,如果希望基于对象的内容生成哈希码,通常需要重写hashCode()方法。为了简化哈希码的计算,我们可以使用Objects工具类,提供了hash方法,可以接受多个参数,并根据它们生成一个合并后的哈希码。

示例如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Data
public class UrlEntity {
    private Integer id;
    private String url;

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        UrlEntity entity = (UrlEntity) o;
        return Objects.equals(id, entity.id) && Objects.equals(url, entity.url);
    }

    @Override
    public int hashCode() {
        return Objects.hash(id, url);
    }

哈希冲突

由于哈希码是一个有限位数的整数,不同的对象可能生成相同的哈希码,这就是哈希冲突。为了最小化哈希冲突的概率,好的哈希码应该能够均匀分布。在实际应用中,可以通过一些技巧和算法来提高哈希码的质量,减少冲突的可能性。

比如如下代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public static void main(String[] args) {
    String str1 = "3C";
    String str2 = "2b";
    System.out.println("字符串"+str1+"的hashCode值为:"+str1.hashCode());
    System.out.println("字符串"+str2+"的hashCode值为:"+str2.hashCode());
}

运行结果为:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
字符串3C的hashCode值为:1648
字符串2b的hashCode值为:1648

不同的对象,却拥有了相同的 hashCode值, 这就是哈希冲突。

为什么重写equals方法时一定要重写hashCode方法

在Java中,equals 方法和 hashCode 方法之间存在一种协定,这个协定规定了如果两个对象根据 equals 方法被认为相等,那么它们的 hashCode 值必须相等。反之亦然,如果两个对象的 hashCode 值相等,它们不一定要相等。

这一规定的原因在于,在使用基于散列的集合类(例如 HashMap、HashSet 等)时,对象的 hashCode 值通常用于确定对象在内部存储结构中的位置。当你在集合中使用对象时,集合会首先检查对象的 hashCode 值,然后再使用 equals 方法来确保这个位置上没有相等的对象。

如果你重写了 equals 方法但没有重写 hashCode 方法,那么可能会导致违反这个协定,即相等的对象具有不同的 hashCode 值。这样的情况会导致在使用散列集合时出现问题,因为相等的对象应该被视为相等,它们应该在集合中占据相同的位置。

总结

在Java中,Object.hashCode()方法在处理集合类和对象比较时发挥着关键作用。了解其原理以及如何正确重写这个方法对于编写高效、正确的代码至关重要。通过理解哈希码的生成方式,我们可以更好地利用Java的集合类,并确保我们的自定义类在使用这些类时能够正确地工作。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2023-12-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 修己xj 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
深入理解Java中的Object类的equals()和hashCode()
在Java编程中,Object类是所有类的基类,它提供了一些基本的方法来操作对象。其中,equals()和hashCode()是两个重要的方法,它们在处理对象比较和哈希码计算方面具有关键作用。本文将深入探讨这两个方法的联系以及它们在Java编程中的应用。
IT_陈寒
2023/12/13
3260
为什么重写 equals() 时必须重写 hashCode() 方法?(简单易理解)
所以在涉及到hashcode的容器中(比如HashSet),判断自己是否持有该对象时,会先检查hashCode是否相等,如果hashCode不相等,就会直接认为不相等,并存入容器中,不会再调用equals进行比较。
人不走空
2024/02/20
1.4K0
为什么重写 equals() 时必须重写 hashCode() 方法?(简单易理解)
Java实战入门:深入解析Java中的hashCode()方法
在Java编程中,hashCode()方法是一个非常重要的方法,尤其是在涉及到集合类(如HashMap、HashSet等)时。本文将详细解析Java中的hashCode()方法,包括其定义、作用、如何正确实现、以及它在实际应用中的重要性。 取材自该网站:Java方法
E绵绵
2024/05/31
1.1K0
Java基础提升篇:equals()与hashCode()方法详解
概述 java.lang.Object类中有两个非常重要的方法: 1public boolean equals(Object obj) 2public int hashCode() 3 Object类是类继承结构的基础,所以是每一个类的父类。所有的对象,包括数组,都实现了在Object类中定义的方法。 equals()方法详解 equals()方法是用来判断其他的对象是否和该对象相等. equals()方法在object类中定义如下: 1public boolean equals(Object obj)
好好学java
2018/07/02
4280
关于equals和hashCode,看这一篇真的就够了
这几天在尝试手撸一个类似Lombok的注解式代码生成工具,用过Lombok的小伙伴知道,Lombok可以通过注解自动帮我们生产equals()和hashCode()方法,因此我也想实现这个功能,但是随着工作的深入,我发现其实自己对于equals()和hashCode()的理解,也处在一个很低级的阶段。
Bug开发工程师
2020/04/16
4250
关于equals和hashCode,看这一篇真的就够了
Java基础篇:什么是hashCode 以及 hashCode()与equals()的联系
hashCode就是对象的散列码,是根据对象的某些信息推导出的一个整数值,默认情况下表示是对象的存储地址。通过散列码,可以提高检索的效率,主要用于在散列存储结构中快速确定对象的存储地址,如Hashtable、hashMap中。
全栈程序员站长
2021/04/13
2.4K0
Java基础篇:什么是hashCode 以及 hashCode()与equals()的联系
Java基础不简单,谈谈hashCode()和equals()之间的联系
其实很早我就注意到阿里巴巴Java开发规范有一句话:只要重写 equals,就必须重写 hashCode。
java技术爱好者
2021/07/12
3510
Java基础不简单,谈谈hashCode()和equals()之间的联系
引以为戒:避免在Set中使用未重写equals和hashCode的引用对象进行去重
在日常的Java开发中,我们经常会使用Set集合来实现去重操作,确保集合中不含有重复的元素。然而,如果使用未重写equals()和hashCode()方法的引用对象进行去重,可能会导致意外的行为,最近了在项目中就遇到了这个情况,让我们深入探讨这个问题,并引以为戒,确保正确实现去重操作。
修己xj
2023/08/25
4710
引以为戒:避免在Set中使用未重写equals和hashCode的引用对象进行去重
java hashCode是什么?有什么作用?
hashCode() 是一个Java中的方法,它返回对象的哈希码(hash code)。hashCode是由对象根据其特征属性计算得出的一个整数值。它用于快速识别对象并在哈希表等数据结构中进行高效的存储和检索。
高久峰
2023/07/13
1.4K0
Java基础系列(十八):Object类(下)
在Java中,hash code(散列码)是由对象导出的一个整型值,以下是几个常见哈希值的算法:
山禾说
2019/01/21
3840
为什么重写 equals 方法时必须同时重写 hashCode 方法?
本文由 Java 中常见的面试题「为什么重写 equals 方法时必须同时重写 hashCode 方法?」所引出。渐进式探讨关于 hashCode 的三个问题:hashCode 方法的作用以及 hashCode 方法与 equals 方法的关系?为什么重写 equals 方法时必须同时重写 hashCode 方法?以及如何重写 hashCode 方法?
每周聚焦
2024/10/28
1320
为什么重写 equals 方法时必须同时重写 hashCode 方法?
equals() ? ==? hashCode()? 今天就把你们都认识清楚
byte,short,char,int,long,float,double,boolean 他们之间的比较,应用双等号(==),基础数据类型比较的是他们的值。
Java宝典
2021/04/22
4680
hashCode()与equals()的区别
面试官可能会问你:“你重写过hashcode()和equals()么,为什么重写equals ()时必须重写hashCode()方法?”
黑洞代码
2021/01/14
7260
在根类Object中,实现了equals()和hashCode()这两个方法
在根类Object中,实现了equals()和hashCode()这两个方法   equals()是对两个对象的地址值进行的比较(即比较引用是否相同),用==实现。   hashCode():计算出对象实例的哈希码。根类Object的hashCode()方法的计算依赖于对象实例的内存地址,即内存地址由哈希函数生成一个int值,故每个Object对象的hashCode都是唯一的;当然,当对象所对应的类重写了hashCode()方法时,结果就截然不同了。之所以有hashCode方法,是因为在批量的对象比较中,hashCode要比equals来得快,很多集合都用到了hashCode,比如Hashtable。
用户7365393
2021/10/07
6180
踩坑集锦之hashcode计算
但是这个答案存在问题,因为没有考虑到hashcode出现负数的情况,为什么hashcode会出现负数呢?
大忽悠爱学习
2023/05/09
1K0
Java HashCode详解
一、为什么要有Hash算法 Java中的集合有两类,一类是List,一类是Set。List内的元素是有序的,元素可以重复。Set元素无序,但元素不可重复。要想保证元素不重复,两个元素是否重复应该依据什么来判断呢?用Object.equals方法。但若每增加一个元素就检查一次,那么当元素很多时,后添加到集合中的元素比较的次数就非常多了。也就是说若集合中已有1000个元素,那么第1001个元素加入集合时,它就要调用1000次equals方法。这显然会大大降低效率。于是Java采用了哈希表的原理。哈希(Hash)
汤高
2018/01/11
4.1K0
Java HashCode详解
【面试题精讲】hashCode有什么用?
hashCode() 是 Java 中的一个方法,它用于返回对象的哈希码。哈希码是根据对象的内容计算出来的一个整数值。
程序员朱永胜
2023/10/08
4680
Java基础(九):Object 类的使用
使用native关键字说明这个方法是原生函数,也就是这个方法是用C/C++等非Java语言实现的,并且被编译成了DLL,由Java去调用
冬天vs不冷
2025/01/21
1580
Java基础(九):Object 类的使用
为什么重写equals必须重写hashCode
如果我们不重写equals和hashcode,那么它使用的是Object方法的实现。我们先简单看一下
一个程序员的成长
2021/12/08
1.7K0
详解equals()方法和hashCode()方法
Java的基类Object提供了一些方法,其中equals()方法用于判断两个对象是否相等,hashCode()方法用于计算对象的哈希码。equals()和hashCode()都不是final方法,都可以被重写(overwrite)。
Java团长
2018/08/06
4340
相关推荐
深入理解Java中的Object类的equals()和hashCode()
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验