[JAVA笔记]-基础-HashCode()、equals()的区别

HashCode()、equals()的区别

hashCode()方法和equals()方法作用。

hashcode()和equals()都是0bject类中的方法。

- 如果类中不重写此方法:
- hashCode():属于是本地方法,返回的是对象的地址值;
- equals():用来比较两个对象的地址值是否相等。

- 如果类中重写此方法。
- hashcode):返回的是根据对象的成员变量,计算出的一个整数。
- equals():比较的是两个对象中成员息是否相同。

类中重写hashcode)和equals()比较两个对象是否相等。

  • 两个对象通过equals)比较是相等的,那么hashcodeO肯定相等,也就是equals)是绝又对可靠的。
  • 两个对象通过hashcode)比较相等,但是equals)去做比较不一定相等,也就是hashcode()不是绝对可靠的。
  • 例子:
public class HashCode_Equals_Compare {
    public static void main(String[] args) {
        Student student1 = new Student("通话",23);
        Student student2 = new Student("重地",23);

        //两个对象通过hashcode()比较相等,但是equals()去做比较不一定相等,也就是说hashcode()不是绝对可靠的!
        System.out.println("hashcode值是否相等:"+(student1.hashCode() == student2.hashCode()));//true
        System.out.println("equals()比较内容值/成员信息是否相等:"+(student1.equals(student2)));//false
    }
}

class Student {
    String name;
    int age;
    //这里省略空参,有参构造,set(),get(),hashcode(),equals()方法.
}

通过hashcode()和equals)搭配使用比较对象是否相等,是如何提高效率的,

  • 问题:对于一个对象中有大量的成员信息,用equals比较会降低效率。
  • 解决:可以先通过hashcode)进行比较,如果不相等则两个对象一定不同、如果相同、再通过equals()进行比较,这样既可以判断对象是否相同又可以提高效率.

HashSet保证元素唯一性的原理?。

通过查看add方法的源码,我们知道了添加功能的执行过程中,是进行了数据的判断的。这个判断的流程是: 首先比较对象的哈希值是否相同,这个哈希值是根据对象的hashcode)计算出来的。

  • 如果哈希值不同,就直接添加到集合中。
  • 如果哈希值相同,继续执行equals)进行比较,返回的是true,说明元素重复,不添加。。返回的是false,说明元素不重复,就添加。
  • 结论:如果我们使用Hashset集合存储对象,你要想保证元素的唯一性,就必须重写hashCode()和equals()方法。 image
更新时间:2019-10-18 15:14:04

本文由 Alicyu 创作,如果您觉得本文不错,请随意赞赏
采用 知识共享署名4.0 国际许可协议进行许可
本站文章除注明转载/出处外,均为本站原创或翻译,转载前请务必署名
原文链接:https://www.alicyu.com/archives/hashcode-equals
最后更新:2019-10-18 15:14:04

Your browser is out of date!

Update your browser to view this website correctly. Update my browser now

×