经常被简单的理解为equals方法用来比较两个对象是否相同,
而==比较运算符用来比较两个基本数据类型的数值是否相同。
这样的理解无可厚非,但还要透过简单看看本质,才会更清晰。
1,基本数据类型的值。
int x = 3;
int y = 3;
System.out.println(x==y);//true
对于基本数据类型的值只能用 == 比较运算符进行比较是否相等。
那么对于引用数据类型呢?
2,引用数据类型的比较。
Demo d1 = new Demo();
Demo d2 = new Demo();
System.out.println(d1==d2);//比较的是d1和d2的内存地址是否相等。
System.out.println(d1.equals(d2));//Demo类继承了Object类中的equals方法
两条输出语句的结果都是false,为什么?
第一句原因:
用new操作符创建的对象都会在内存中分配一个新的内存地址。
所以两个对象的内存地址不同,为false。
第二句原因:
必须明确equals到底比较的是对象的什么?查看Object类的equals方法源码:
public boolean equals(Object obj) {
return (this == obj);
}
发现内部使用的也是 == 运算符比较的。
所以在对象的比较相同上 == 和equals是一样的。
那有的同学就问了,那equals方法还有什么用呢?
虽然每个对象都有自己的内存地址,但是每个对象也有自己的一些特有的特征。
比如学生对象有自己的姓名和年龄,希望根据姓名和年龄的相同来判断学生对象是否相同。
这时使用Object类的equals就不能满足需求了,
就需要通过覆盖equals的方式,建立学生对象比较相同的具体内容。
public boolean equals(Object obj){
if(姓名和年龄相同)
return true;
return false;
}
Student s1 = new Student("zhangsan",20);
Student s2 = new Student("zhangsan",20);
System.out.println(s1==s2); //结果是false,比较两个对象的地址。
System.out.println(s1.equals(s2));//结果是true,比较的是对象的具体内容。
所以,在用Java的类描述对象的时候,如果要判断该对象是否相同时,通常都会
覆盖equals方法,建立根据该对象特征进行比较相同的依据。
这也就是大家常听到的“equals是用来比较对象内容”的原因。
Java中很多对象都覆盖了equals方法,建立该对象特有的比较相同的方式。
比如String,Integer,Boolean等。 |