转自 https://www.cnblogs.com/silence-hust/p/4558701.html
一、为什么要重写equals方法呢?
因为继承Objec的equals方法只能判断两个对象是否是同一个对象。可是我们认为常用的equals方法应该具有逻辑判断功能,所以我们重写equals方法,可以按照我们所需的要求自定义。
二、怎样重写equals方法?
1.自反性:对于任何非空引用x,x.equals(x)应该返回true。
2.对称性:对于任何引用x和y,如果x.equals(y)返回true,那么y.equals(x)也应该返回true。
3.传递性:对于任何引用x、y和z,如果x.equals(y)返回true,y.equals(z)返回true,那么x.equals(z)也应该返回true。
4.一致性:如果x和y引用的对象没有发生变化,那么反复调用x.equals(y)应该返回同样的结果。
5.非空性:对于任意非空引用x,x.equals(null)应该返回false。
三、代码
public class Person {
private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public boolean equals(Object obj) {
if (this == obj) return true; //自反性
if (obj == null || this.getClass() != obj.getClass()) { //传递性,非空性
return false;
}
Person person = (Person) obj;
return this.getName().equals(((Person) obj).getName()) &&
this.getAge() == ((Person) obj).getAge();
}
@Override
public int hashCode() {
return Objects.hash(getName(), getAge());
}
}