转自 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()); } }