HashCode和equals方法

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

都是Object类中的方法

如果类中不重写此方法

  • hashCode():属于是本地方法,返回的是对象的地址值
  • equals():用来比较两个对象的地址值是否相等

如果类中重写此方法

  • hashCode() :返回的是根据对象的成员变量,计算出的一个整数
  • equals():比较的是两个对象中成员信息是否相同

在HashSet集合中,通过hashCode()和quals(),保证元素的唯一性

hashSet保证元素唯一性的原理?

通过查看add方法的源码,我们知道了添加共嫩格得执行过程中,是进行了数据的判断的

这个判断的流程是:

首先比较对象的哈希值是否相同,这个哈希值是根据对象的hashCode()计算出来的

  1. 如果哈希值不同,就直接添加集合中
  2. 如果哈希值相同,继续执行equals()进行比较
  • 返回的是true,说明元素重复,不添加

  • 返回的是false,说明元素不重复,就添加

 

结论:如果我们使用HashSet集合存储对象,你要想保证元素的唯一性,就必须重写hashCode()和equals()方法

 


版权声明:本文为qq_35936973原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。