java中 equals 和 hashcode 的关系

一 ,hashCode()和equals()是什么?

hashCode()和equals()方法作用时一样的,都是为了判断两个对象是否相等。

二 ,hashCode()和equals()的区别

下边从两个角度介绍了他们的区别:一个是性能,一个是可靠性。他们之间的主要区别也基本体现在这里。

1、equals()既然已经能实现对比的功能了,为什么还要hashCode()呢?

因为重写的equals()里一般比较的比较全面比较复杂,这样效率就比较低,而利用hashCode()进行对比,则只要生成一个hash值进行比较就可以了,效率很高。

2、hashCode()既然效率这么高为什么还要equals()呢?

因为hashCode()并不是完全可靠,有时候不同的对象他们生成的hashcode也会一样(生成hash值得公式可能存在的问题),所以hashCode()只能说是大部分时候可靠,并不是绝对可靠,所以我们可以得出(PS:以下两条结论是重点,很多人面试的时候都说不出来):

equals()相等的两个对象他们的hashCode()肯定相等,也就是用equals()对比是绝对可靠的。

hashCode()相等的两个对象他们的equals()不一定相等,也就是hashCode()不是绝对可靠的。

三、hashCode()和equals()使用的注意事项

1、对于需要大量并且快速的对比的话如果都用equals()去做显然效率太低,所以解决方式是,每当需要对比的时候,首先用hashCode()去对比,如果hashCode()不一样,则表示这两个对象肯定不相等(也就是不必再用equals()去再对比了),如果hashCode()相同,此时再对比他们的equals(),如果equals()也相同,则表示这两个对象是真的相同了,这样既能大大提高了效率也保证了对比的绝对正确性!

2、这种大量的并且快速的对象对比一般使用的hash容器中,比如HashSet,HashMap,HashTable等等,比如HashSet里要求对象不能重复,则他内部必然要对添加进去的每个对象进行对比,而他的对比规则就是像上面说的那样,先hashCode(),如果hashCode()相同,再用equals()验证,如果hashCode()都不同,则肯定不同,这样对比的效率就很高了。

3、然而hashCode()和equals()一样都是基本类Object里的方法,而和equals()一样,Object里hashCode()里面只是返回当前对象的地址,如果是这样的话,那么我们相同的一个类,new两个对象,由于他们在内存里的地址不同,则他们的hashCode()不同,所以这显然不是我们想要的,所以我们必须重写我们类的hashCode()方法,即一个类,在hashCode()里面返回唯一的一个hash值。
比如下面:
在这里插入图片描述
由于标识这个类的是他的内部的变量num和name,所以我们就根据他们返回一个hash值,作为这个类的唯一hash值。

所以如果我们的对象要想放进hashSet,并且发挥hashSet的特性(即不包含一样的对象),则我们就要重写我们类的hashCode()和equals()方法了。像String,Integer等这种类内部都已经重写了这两个方法。

当然如果我们只是平时想对比两个对象 是否一致,则只重写一个equals(),然后利用equals()去对比也行的。

原文:https://blog.csdn.net/xlgen157387/article/details/88087963

### 回答1: 在 Java equals() 和 hashCode() 是两个重要的方法,用于判断对象是否相等和哈希值的计算。 equals() 方法用于比较两个对象是否相等。默认情况下,它使用 == 运算符比较对象的引用,即比较两个对象是否指向同一个内存地址。如果想比较两个对象的属性是否相等,就需要重写 equals() 方法,并根据对象的属性进行比较。 hashCode() 方法用于计算对象的哈希值,即将对象映射为一个整数。哈希值在 Java 经常用于散列表等数据结构,用于快速查找和比较对象。如果两个对象相等,它们的哈希值应该相同。因此,重写 equals() 方法的同时,也需要重写 hashCode() 方法。 在重写 equals() 和 hashCode() 方法时,需要遵循一些规则。比如,如果两个对象相等,它们的 hashCode() 方法应该返回相同的值;反之,如果两个对象的 hashCode() 值相等,它们不一定相等,还需要通过 equals() 方法进行比较。此外,hashCode() 方法不能依赖于对象的内存地址或时间戳等不稳定因素,应该根据对象的属性计算哈希值。 ### 回答2: JavaequalshashCode是非常重要的两个方法,在Java几乎所有的类都会覆盖它们,而且它们是非常重要的类比较和哈希计算的方法。 equals方法用于比较两个对象是否相等,通常比较两个对象的内容是否相同,他们是否具有相同的属性和值。 equals方法的默认实现是比较两个对象的引用是否相同,即两个对象是否是同一个对象,不过这个默认的实现并不能满足所有的需求,因为有时候即使两个对象的引用不同,但他们的内容依然相同,所以需要重写equals方法来实现内容的比较。 另一方面,hashCode方法则是将一个对象映射成一个整型的哈希值,通常用于快速查找或比较对象。 在Java,哈希表是非常常见的数据结构,而哈希值就是在哈希表用来寻找和比较对象的唯一标识,所以hashCode方法的实现对于哈希表的性能有着非常重要的影响。 需要注意的是,hashCode方法必须和equals方法保持一致性,也就是说如果两个对象的equals方法返回true,那么他们的hashCode方法返回的哈希值必须相同,反之亦然。 在实现equals方法时,一般会遵循一些基本原则,例如对称性,传递性,一致性等,同时还需要注意适当的判断null值和使用instanceof进行类型判断。在实现hashCode方法时,需要确保相同的对象始终返回相同的哈希值,同时也需要尽可能的让不同的对象返回不同的哈希值。 总之,JavaequalshashCode方法是非常重要的两个方法,深入理解其实现原理和使用方式,可以有效提高Java应用程序的性能和稳定性。 ### 回答3: Javaequals()和hashCode()是两个非常重要的方法,它们用于判断对象之间的相等性和排序性。 equals()方法是用来比较两个对象是否相等的,它的作用是比较两个对象的内容是否相等,而不是比较两个对象引用是否相等。在默认情况下,equals()方法会比较两个对象的引用,即判断两个对象是否指向同一个内存地址。但是,我们通常需要自己来重写equals()方法,以便在比较对象时只比较对象的内容。 hashCode()方法是Java的哈希函数,它将对象映射到一个整数值。这个整数值通常用于将对象存储到哈希表,可以快速地定位对象。如果两个对象相等,那么它们的hashCode()方法返回的整数值也应该相等。因此,在重写equals()方法时,我们也需要重写hashCode()方法。 在Java,如果两个对象调用equals()方法返回true,那么它们的hashCode()方法返回的整数值也必须相等。因此,重写hashCode()方法时,必须保证相等的对象返回相等的hashCode()值,否则将会影响哈希表的性能。同时,hashCode()方法的重写也应该考虑到对象的内容,以便产生尽可能不同的哈希值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值