JAVA中,为啥object对象中的equals方法比较的是同一,而String对象比较的是相等?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA中,为啥object对象中的equals方法比较的是同一,而String对象比较的是相等?相关的知识,希望对你有一定的参考价值。
因为在java中,Object类是所有类的始祖,所有类都直接或者间接继承了它。Object类中equals方法比较的是两个对象是否具有相同的引用,如果两个对象的引用都一样(即指向同一块内存),那它们一定是相等的。至于为什么要这样设计,因为Object没办法判断是什么来继承他,不能具体的去实现这个逻辑,因此交给它的子类自己根据自己的特征去重写这个方法。举个列子,比如定义了一个人类Person,有子类学生Student和员工Employee类,这时候Person类里面可以有name,age等这些通用的属性。但如果在Person里面定义一个简介(getIntroduction())的方法,就不好具体去叙述,这时候就可以交给子类自己去重写这个方法,比如Student类的getIntroduction()方法里面可以写“什么学校、什么专业、什么年级”等,Employee类里面就可以写“什么行业、什么职位”等。
所以Object很直接,不管你是什么类型,怎么进行比较,只要你们指向同一块内存,那你们就相等。比如String类,重写equals方法后比较的是字符串的具体值,但谁也不能否认,两个引用指向同一个地址时,值也一样相等。
---------------------刚好看到这,顺势把个人理解叙述一下,希望有用---------------- 参考技术A 因为String类里面已经覆盖了equals方法。所以比较的是对象的内容,但是如果是数组的话就不行,因为数组没有覆盖equals方法,所以比较的是对象的引用。覆盖的代码如下
@Override
public boolean equals(object obj)
if(obj instanceof Employee)
return this.id = ((Employee)obj).id;
else
return false;
参考技术B 类Object
equals方法对于任何非空的参考值x和y,此方法返回true当且仅当x和y引用同一个对象(x
== y有价值true)。
java--面对对象之Object类
一、概念
Object类是Java语言中的根类,即所有类的父类。它中描述的所有方法子类都可以使用。所有类在创建对象的时候,最终找的父类就是Object。在Object类众多方法中,我们先学习equals方法与toString方法,其他方法后面课程中会陆续学到。
二、equals方法
equals方法,用于比较两个对象是否相同,它其实就是使用两个对象的内存地址在比较。Object类中的equals方法内部使用的就是==比较运算符。在开发中要比较两个对象是否相同,经常会根据对象中的属性值进行比较,也就是在开发经常需要子类重写equals方法根据对象的属性值进行比较。如下代码演示:
1 /* 2 描述人这个类,并定义功能根据年龄判断是否是同龄人 3 由于要根据指定类的属性进行比较,这时只要覆盖Object中的equals方法 4 在方法体中根据类的属性值进行比较 5 */ 6 class Person extends Object{ 7 int age ; 8 //复写父类的equals方法,实现自己的比较方式 9 public boolean equals(Object obj) { 10 //判断当前调用equals方法的对象和传递进来的对象是否是同一个 11 if(this == obj){ 12 return true; 13 } 14 //判断传递进来的对象是否是Person类型 15 if(!(obj instanceof Person)){ 16 return false; 17 } 18 //将obj向下转型为Perosn引用,访问其属性 19 Person p = (Person)obj; 20 return this.age == p.age; 21 } 22 }
注意:在复写Object中的equals方法时,一定要注意public boolean equals(Object obj)的参数是Object类型,在调用对象的属性时,一定要进行类型转换,在转换之前必须进行类型判断。
三、toString方法
toString方法返回该对象的字符串表示,其实该字符串内容就是对象的类型+@+内存地址值。
由于toString方法返回的结果是内存地址,而在开发中,经常需要按照对象的属性得到相应的字符串表现形式,因此也需要重写它。
1 class Person extends Object{ 2 int age ; 3 //根据Person类的属性重写toString方法 4 public String toString() { 5 return "Person [age=" + age + "]"; 6 } 7 }
例如:
Person类
1 public class Person { 2 private String name; 3 private int age; 4 Person(){ 5 6 } 7 Person(String name,int age){ 8 this.name=name; 9 this.age=age; 10 } 11 12 public boolean equals(Object obj) {//Object obj=new Person(); 13 //调用子类都有的成员,需要向下转型 14 if(obj==null){ 15 return false; 16 } 17 if(obj==this){ 18 return true; 19 } 20 if(obj instanceof Person ){ 21 Person p=(Person)obj; 22 return this.age==p.age; 23 } 24 return false; 25 } 26 @Override 27 public String toString() { 28 return "Person [name=" + name + ", age=" + age + "]"; 29 } 30 31 /*public String toString() { 32 33 return "name:"+name+",age:"+age; 34 }*/ 35 36 }
测试类
1 public class Demo01 { 2 3 public static void main(String[] args) { 4 Person p1=new Person("熊大",2); 5 Person p2=new Person("熊二",2); 6 ArrayList<String> list=new ArrayList<String>(); 7 System.out.println(p1==p2); //false 8 System.out.println(p1.equals(list)); //false 9 System.out.println(p1);//默认打印tostring() 子类方法重写后 就变成子类重写方法 10 System.out.println(p2); 11 }
以上是关于JAVA中,为啥object对象中的equals方法比较的是同一,而String对象比较的是相等?的主要内容,如果未能解决你的问题,请参考以下文章
java中重写Object类的equals方法为啥要重写hashcode方法?不重写可以吗?