我们有的时候要判断我们自己定义的类生成的对象的值是否相等,这时候就要重写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