我们有的时候要判断我们自己定义的类生成的对象的值是否相等,这时候就要重写equals方法,如果不重写,就无法判断两个对象的值是否相等! Object类是我们自己定义类的父类,在Object类中equals方法是这样的:
public boolean equals(Object obj) { return (this == obj); }
很显然,他不能帮我们判断 两个对象的值 是否相等,他只是直接判断 对象的引用是否相等,判断的是地址!
所以我们要重写equals方法。
java语言规范要求equals方法具有下面的特性: (1)自反性:对于任何非空引用x,x.equals(x)应该返回true; (2)对称性:对于任何引用x,和y,当且仅当,y.equals(x)返回true,x.equals(y)也应该返回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;
即 重写的equals方法要满足以上的五种特性!
一下是一个重写equals方法的例子
Student.java
public class Student { private String name; private int age; public Student(String name, int age) { super(); this.name = name; this.age = age; } public boolean equals(Object obj){ if(obj == this){ return true; } if (obj == null){ return false ; } else{ if (obj instanceof Student){ Student c = (Student) obj; if(c.name==this.name && c.age==this.age ){ return true ; } } } return false ; } }
Demo.java
public class Demo { public static void main(String[] args) { Student a = new Student("zhangsan",12); Student b = new Student("zhangsan",12); System.out.println(a.equals(b)); //true System.out.println(a.equals(a)); //true System.out.println(a.equals(null)); //false } }
每个重写了equals方法的类,也必须重写hashCode方法!
如果不这样的话,就会违反Object.hashCode的通用约定,从而导致该类无法结合所有基于散列的集合一起正常运作,这样的集合包括HashMap、HashSet和Hashtable。
以后会重写hashCode