Java中子类调用Object类中的方法为什么不用super?如:问题补充的代码,打印出来为False,如何解释?

2024-11-20 03:34:26
推荐回答(3个)
回答1:

你好,你问的这个问题就涉及到了java中Object这个类的一些属性了。在Java中,Object作为所有对象的超类,是最初的顶级父类。而我们自定义新建的其他类,比如(Animal等等),默认都继承了Object这个类,所以也就继承了Object的定义的一些方法,比如(toString等等);
而在你的代码中,虽然oo1与oo2的参数值一样,但是却是false,这是因为java语言是一种面向对象的语言。所以在堆栈中就会每一个创建的对象分配一块内存,因为你的oo1,oo2是两个对象,所以尽管参数一样,但是他们却不"相等".
希望能帮到你。

回答2:

要解释这个问题要先解释下“==”操作符和equals方法的区别:
==操作符专门用来比较两个变量的值是否相等,也就是用于比较变量所对应的内存中所存储的数值是否相同,要比较两个基本类型的数据或两个引用变量是否相等,只能用==操作符。
如果一个变量指向的数据是对象类型的,那么,这时候涉及了两块内存,对象本身占用一块内存(堆内存),变量也占用一块内存,例如Objet obj = new Object();变量obj是一个内存,new Object()是另一个内存,此时,变量obj所对应的内存中存储的数值就是对象占用的那块内存的首地址。对于指向对象类型的变量,如果要比较两个变量是否指向同一个对象,即要看这两个变量所对应的内存中的数值是否相等,这时候就需要用==操作符进行比较。
equals方法是用于比较两个独立对象的内容是否相同,就好比去比较两个人的长相是否相同,它比较的两个对象是独立的。例如,对于下面的代码:

String a=new String("foo");
String b=new String("foo");
两条new语句创建了两个对象,然后用a,b这两个变量分别指向了其中一个对象,这是两个不同的对象,它们的首地址是不同的,即a和b中存储的数值是不相同的,所以,表达式a==b将返回false,而这两个对象中的内容是相同的,所以,表达式a.equals(b)将返回true。
如果一个类没有自己定义equals方法,那么它将继承Object类的equals方法,Object类的equals方法的实现代码如下:
boolean equals(Object o){
return this==o;
}
这说明, 如果一个类没有自己定义equals方法,它默认的equals方法(从Object类继承的)就是使用==操作符,也是在比较两个变量指向的对象是否是同一对象,这时候使用equals和使用==会得到同样的结果,如果比较的是两个独立的对象则总返回false。如果你编写的类希望能够比较该类创建的两个实例对象的内容是否相同,那么你必须覆盖equals方法,由你自己写代码来决定在什么情况即可认为两个对象的内容是相同的。

回答3:

Object类是所有类的父类,是最上层的类,super是调用父类的方法,他没有父类,所以不能调用
对象使用==比较的话,是比较这两个对象的内存地址的,所以显示false