本文主要是介绍解读Object类的equals方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Object类中的equals方法,使用的是双等号进行的引用的比较
class Student{
String name;
int age;
public Student(){}
public Student(String name;int age){
this.name=name;
this.age=age;
}
}
public class TestStudent{
public static void main(String[] args){
Student stu1 = new Student("Tom",18);
Student stu2 = new Student("Tom",18);
System.out.println(stu1 == stu2);
System.out.println(stu1.equals(stu2));
}
}
上面的两个输出都是false,第一个false是因为stu1和sutu2两个引用分别指向两个不同的对象,两个引用所存放的地址是不同的,所以返回值为false
但是第二个输出语句中,我们调用了两个equals方法来比较两个对象,在这两个对象中,两个学生的姓名相同,年龄也相同,但是比较的结果依然是false,这是为什么呢?
其实,我们在Student类中并没有定义equals方法,这里的equals方法是从Object类中继承来的,而Object类中的equals方法在进行判断的时候,判断的是引用是否相等
Object类中equals方法的源码:
public boolean equals(Object obj){
return (this==obj);
}
可以看到,在Object类中的equals方法,使用的是双等号进行的比较,因此,Object类中的equals方法不能够帮助我们比较两个学生对象的内容是否相等.
这时候我们就需要覆盖Object类的equals方法,由程序员指定两个对象的比较规则.
在覆盖equals方法之前我们先来解决一个疑问:
String str1 = new Sting("abc");
String str2 = new Sting("abc");
System.out.println(str1 == str2);//输入出false
System.out.println(str1.equals(str2));//输出true
我们知道equals方法其实是比较的两个引用的值,这里str1和str2明显是两个不同的引用,但是为什么这里能够输出true呢?
其实在String类里面已经覆盖了equals方法了,这时候不再是使用的Object类的equals方法了.
下面我们来覆盖equals方法:
public boolean equals(Object obj){
//判断obj是否和this相等,保证自反性
if (obj == this) return true;//自己和自己比较,一定是返回true
//判断obj是否为null
if(obj == null) return false;//当前对象不为null,obj对象为null,一定返回false
//判断两个对象的实际类型是否相等,如果不相等,则说明比较的是两个不同种类的对象,应当返回false
if(obj.getClass() != this.getClass()) return false;
Student stu = (Student) obj;//强制类型转换,由于之前已经使用getClass判断过实际类型,因此这里强转安全的
//判断每个属性是否相等
//对于基本类型的属性用"=="比较,对象类型的属性用equals比较
if(this.age == stu.age && this.name.equals(stu.name))
return true;
else return false;
}
总结一下,覆盖equals方法的五个步骤:
1.判断 this == obj
2.判断 obj == null
3.判断两个对象的实际类型(使用getClass()方法)
4.强制类型转换
5.依次判断两个对象的属性是否相等
这篇关于解读Object类的equals方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!