您的位置:首页 > 移动开发 > Objective-C

解读Object类的equals方法

2014-08-07 19:29 393 查看
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.依次判断两个对象的属性是否相等
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: