快速理解HashSet重写hashCode和equals方法

重写原因:
1、HashSet是根据hashCode值来判断对象是否是同一个。
2、hashCode不等,2个对象一定不等
3、我们希望2个对象属性值都相同的时候,当成同一个对象,所有需要重写hashCode和equals方法(本质:根据对象属性的值来重写,保证属性值一样时,重写后的hashCode一定相同,equals方法一定为true)

注:我们都知道,‘’比较两个引用是否指向同一个对象(实际就是比较内存地址),‘equals’比较两个对象的内容。当然这里的equals()方法是被重写过才能去比较内容相等的吧(当然基本数据类型直接用,string为引用数据类型,调用String类本身重写的equals方法)。

技术背景:
1、HashSet对象中不能存储相同的数据(是按照哈希值来存的所以取数据也是按照哈希值取得),存储数据时是无序的
2、以下是关于hashcode的一些规定:
两个对象相等,hashcode一定相等
两个对象不等,hashcode不一定不等
hashcode相等,两个对象不一定相等
hashcode不等,两个对象一定不等
3、默认Java中所有类的顶级父类的object对象,如果没有继承的关系的话,一个类会默认继承 object 对象类,所以对象类中的hashCode()方法方法并没有被重写

业务背景:我们希望当两个对象中的所有值相等时,往HashSet中存储时,就只存一个对象,换句话说,重写HashCode和equals方法后这两个值就是同一个对象。

例子:Student类
快速理解HashSet重写hashCode和equals方法_第1张图片
重写前:
快速理解HashSet重写hashCode和equals方法_第2张图片

重写后:
快速理解HashSet重写hashCode和equals方法_第3张图片

你可能感兴趣的:(面试题)