Java基础之hashcode剖析

本文深入探讨了Java中hashCode()方法的工作原理及其与equals()的关系。强调了在重写equals()时,为何应同时重写hashCode(),以确保集合操作的正确性。通过实例分析了hashCode()在HashMap和HashSet中的作用,以及如何解决哈希冲突。最后,讨论了高效实现hashCode()的重要性,因为它直接影响到哈希表的性能。
摘要由CSDN通过智能技术生成

1. 前言

散列是计算机科学的一个基本概念。在 Java 中,高效的散列算法支持一些最流行的集合,例如HashMap和HashSet,在本文中,我们将重点介绍hashCode() 的工作原理、它如何在集合中使用以及如何正确实现它。

hashcode规则

  • 在equals方法没被修改的前提下,多次调用同一对象的hashcode方法返回的值必须是相同的整数;
  • 如果两个对象互相equals,那么这两个对象的hashcode值必须相等;
  • 为不同对象生成不同的hashcode可以提升哈希表的性能;

目标

  1. 为什么要 重写hashcode 和 equals 方法
  2. 为什么两个对象相等,Set 、Map还是打印两个对象引用?
  3. 只重写equals方法和只重写hashcode方法会出现什么情况?

2. hashcode 原理

2.1 Java equals()和hashCode()的关系

Object.html#hashCode()

hashcode的理解

  1. hashCode的存在主要是用于查找的快捷性,如Hashtable,HashMap等,hashCode是用来在散列存储结构中确定对象的存储地址的;
  2. 如果两个对象相同,就是适用于equals(java.lang.Object) 方法,那么这两个对象的hashCode一定要相同;
  3. 如果对象的equals方法被重写,那么对象的hashCode也尽量重写,并且产生hashCode使用的对象,一定要和equals方法中使用的一致,否则就会违反上面提到的第2点;
  4. 两个对象的hashCode相同,并不一定表示两个对象就相同,也就是不一定适用于equals(java.lang.Object) 方法,只能够说明这两个对象在散列存储结构中,如Hashtable,他们 “存放在同一个篮子里”

再归纳一下就是 hashCode是用于查找使用的,而 equals是用于比较两个对象的是否相等的。以下这段话是从别人帖子回复拷贝过来的,说的很形象:

(1) hashcode是用来查找的,如果你学过数据结构就应该知道,在查找和排序说过:假如内存中有这样的位置 [0 1 2 3 4 5 6 7] 而我有个类,这个类有个字段叫ID,我要把这个类存放在以上8个位置之一,如果不用hashcode而任意存放,那么当查找时就需要到这八个位置里挨个去找,或者用类似二分法的算法。 但如果用hashcode那就会使效率提高很多。

我们这个类中有个字段叫ID,那么我们就定义我们的hashcode为ID%8,然后把我们的类存放在取得得余 数那个位置。比如我们的ID为9,9除8的余数为1,那么我们就把该类存在1这个位置,如果ID是13,求得 的余数是5,那么我们就把该类放在5这个位置。这样ÿ

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值