zoukankan      html  css  js  c++  java
  • Java中Object类的equals()和hashCode()方法深入解析

    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()在某种程度上来得快。

     

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

  • 相关阅读:
    1、线性DP 213. 打家劫舍 II
    如何在CentOS 8上安装Vtiger CRM?
    如何在不使用密码的情况下切换(su)到另一个用户帐户
    如何解决Ubuntu上的Busybox Initramfs错误
    Linux中的16个Echo命令示例
    如何在Ubuntu 20.04 LTS Focal Fossa上安装Grafana
    如何在Ubuntu 20.04上安装Apache ZooKeeper
    如何在Ubuntu 20.04 LTS Focal Fossa上安装Prometheus
    如何在CentOS 8上安装GlassFish
    如何在CentOS 8上安装Netdata Monitoring
  • 原文地址:https://www.cnblogs.com/return/p/1597611.html
Copyright © 2011-2022 走看看