在子类使用super.age=11给父类age赋值,可打印super.age的结果不是11,而是子类的10,求解释!!!
public class FatherSon {
public static void main(String[] args) {
Son son1 = new Son();
son1.greet();
Father father = (Father)son1;
father.greet();
}
}
class Father {
int age = 20;
public void greet() {
System.out.println(age);
}
}
class Son extends Father {
public Son() {
super();
super.age = 11;
this.age = 10;
}
public void greet(int a){
super.greet();
}
public void greet() {
System.out.println(super.age);
System.out.println(age);
}
}
厉害
好像真的是这样子啊
本人菜鸟,想再请教一下,新建了一个son,它的区域中是不是也有father,然后重写的方法,写在father外,son中的区域,然后如果age不重写,无论super,this直接就引用了father的属性?
然后属性的覆盖,是不是不能称之为重写呐?
方法在内存的存放不清楚,反正重写的方法是属于子类自己的,父类看不到。继承过后如果没有覆盖,那么子类从父类继承来的变量与父类的变量指向同一个域,覆盖之后。系统会给子类变量重新开辟一个存储空间。
确实不存在多态
那子类无法调用父类属性?
请问内存空间里,父类和子类的属性就是一个区域吗?
这个问题很纠结
子类和父类的属性是同一个东西,调用自己的跟调用父类的没区别。可以理解为同一个内存空间。
追问不好意思,想刨根问底,我觉得怎么理解是其次,想知道内存里实际的分配是咋样的?这很复杂吗?
追答他们指的是同一块内存,所以改一个就都改了。数据是在堆上的。。。
本回答被网友采纳