为什么重写equals则一定需要重写hashcode

 

主要是为了避免Map,Set内出现重复的元素。

equals是判断两个对象是否相等的判断依据。而hashcode在map中是用来查找对应的对象在数组的下标的。如果equals被重写了而hashcode没有被重写,那么意味着2个equals相同(实际也就是相同)的对象,他们有着不同的数组下标,那么一个map里就有可能出现2个相同的key了,这明显是不合规矩的 

重写equals应满足的规则:

1 自反性         ---------      x.equals(x) 返回true

2 对称性         ---------      若x.equals(y)返回true,那么y.equals(x)返回true

3 传递性         ---------      若x.equals(y) 又有 y.equals(z) 那么 x.equals(z) 返回true

4 一致性         ---------      若x.equals(y)为true,那么无论调用多少次,始终返回true

5 非空性         ---------       x.equals(null)的结果始终未false

发布了40 篇原创文章 · 获赞 6 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/qq_41332728/article/details/102511342