关于equals和hashcode问题

默认情况下也就是从超类Object继承而来的equals方法与‘==’是完全等价的,比较的都是对象的内存地址,但我们可以重写equals方法,使其按照我们的需求的方式进行比较,如String类重写了equals方法,使其比较的是字符的序列,而不再是内存地址。

hashcode是用于散列数据的快速存取,如利用HashSet/HashMap/Hashtable类来存储数据时,都是根据存储对象的hashcode值来进行判断是否相同的。这样如果我们对一个对象重写了euqals,意思是只要对象的成员变量值都相等那么euqals就等于true,但不重hashcode,那么我们再new一个新的对象,当原对象.equals(新对象)等于true时,两者的hashcode却是不一样的,由此将产生了理解的不一致,如在存储散列集合时(如Set类),将会存储了两个值一样的对象。

 

转载于:https://www.cnblogs.com/zhangjianbing/p/9875962.html

equalshashcode是Java中两个重要的方法,用于对象的比较和哈希值计算。它们之间有以下关系: 1. equals()方法用于判断两个对象是否相等。它是Object类的方法,在需要比较自定义对象时,我们通常需要重写这个方法。equals()方法的默认实现是比较对象的引用是否相等,即比较内存地址。但是,对于自定义的类,我们通常需要根据实际情况重写equals()方法,根据对象的内容进行比较。 2. hashcode()方法用于计算对象的哈希值。哈希值是一个整数,用于标识对象在哈希表中的位置。在使用哈希表数据结构时,比如HashMap、HashSet等,hashcode()方法用于确定对象在哈希表中的桶位置。默认情况下,hashcode()方法返回的是对象的内存地址的哈希码。 3. 根据Java规范,如果两个对象使用equals()方法判断相等,则它们的hashcode()方法必须返回相同的值。也就是说,如果两个对象相等,它们的哈希值也必须相等。但是,反过来并不成立:如果两个对象的哈希值相等,并不一定能说明它们相等。 4. 在重写equals()方法时,通常也需要重写hashcode()方法,以保持equals()和hashcode()之间的一致性。这是因为在哈希表等使用哈希值的数据结构中,如果两个对象的哈希值不相等,它们将被认为是不同的对象,即使equals()方法判断它们相等。 综上所述,equals()和hashcode()是相互关联的方法,用于对象的比较和哈希值计算。重写这两个方法需要遵循一定的规范,以确保在使用哈希表等数据结构时能够正常工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值