详细介绍HashCode与Equals的关系
在Java代码规范中,有这样一条规定:如果重写Equals方法,就必须重写HashCode方法。今天就详细来介绍下Equals与HashCode的关系,以及为什么要重写Equals方法。
1.Equals方法
public boolean equals(Object obj) {
return (this == obj);
}
上面这一段是Object类中的Equals方法,明显可以看出这个Equals是比较两个类的地址是否相同。不信可以测试一下。
我们以一个Persion类为例
public class persion {
private int id;
private int age;
private String name;
public persion() { }
public persion(int id,int age,String name){
this.id=id;
this.age=age;
this.name=name;
}
}
测试代码
persion ps1 = new persion(1,18,"xixi");
persion ps2 = new persion(1,18,"xixi");
System.out.println(ps1.equals(ps2));
这段代码运行结果便是false。因为每次New一个对象的话,就会开辟一块新的空间,这样的话Equals比较的就不是内容了,和==就没有区别了。为了使Equals回归自己的使命(即比较两个对象内容是否相同),则需要重写Equals方法。
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
persion persion = (persion) o;
return id == persio

本文详细探讨了Java中HashCode与Equals的关系,强调了如果重写Equals方法,必须重写HashCode方法。讲解了Equals方法默认比较对象地址,而重写后用于比较对象内容。还介绍了HashCode方法在HashSet和HashMap中的作用,解释了哈希冲突和解决策略。通过示例代码展示了不重写和重写这两个方法时,HashSet和HashMap的行为差异。
最低0.47元/天 解锁文章
440

被折叠的 条评论
为什么被折叠?



