Java中Object类的equals()和hashCode()方法深入解析

本文详细解释了Java中equals方法和hashCode方法的工作原理,包括它们在Object类中的默认行为及在如String等类中的重写方式。此外还讨论了这两个方法之间的关系以及为何在集合类中采用这样的设计。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文来自:http://www.cnblogs.com/return/archive/2009/11/06/1597611.html


1.equals()

在初学Java的时候,很多人会说在比较对象的时候,==是比较地址,equals()是比较对象的内容,谁说的?

看看equals()方法在Object类中的定义:

public boolean equals(Object obj){
    
return (this == obj);
}

这是比较内容么?明显是比较指针(地址)么...

 

但是为什么会有equals是比较内容的这种说法呢?

因为在String、Double等封装类中,已经重载(overriding)了Object类的equals()方法,于是有了另一种计算公式,是进行内容的比较。

比如在String类中:

复制代码
public int hashCode() { 
    
int h = hash; 
    
if (h == 0) { 
        
char val[] = value; 
        
int len = count; 
        
for (int i = 0; i < len; i++) { 
            h 
= 31*+ val[off++]; 
        } 
        hash 
= h; 
    } 
    
return h; 
复制代码

 

2.hashCode()

在Object类中的定义为:

public native int hashCode();

是一个本地方法,返回的对象的地址值。

但是,同样的思路,在String等封装类中对此方法进行了重写。方法调用得到一个计算公式得到的 int值

 

3.两者的关系

①两个obj,如果equals()相等,hashCode()一定相等

②两个obj,如果hashCode()相等,equals()不一定相等

原因:从散列的角度考虑,不同的对象计算哈希码的时候,可能引起冲突,大家一定还记得数据结构中冲突的解决方案吧

 

但是要这么设计,用两个函数,个人的理解是为了比较两个对象时更高效。

可以考虑在Java集合中,判断两个对象是否相等的规则是:

第一步,如果hashCode()相等,则查看第二步,否则不相等;

第二步,查看equals()是否相等,如果相等,则两obj相等,否则还是不相等。

 

为什么这样做?个人的理解是让适当的函数完成适当的功能,毕竟hashCode()比equals()在某种程度上来得快。

 

(个人心得,若有错误,请指正)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值