关于java子类中使用super为何不能调用父类属性的疑问

在子类使用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);
}
}

你把打印的结果拿来看下 ,而且父类型指向子类型不需要强制转换。
楼下的,子类中的age和父类中的age是同一个age?
楼主,应该是你的son没有覆盖age的定义,所以你的super.age和thsi.age都是用的父类的age,所以
public class FatherAndSon {
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 {
int age=10;
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);
}
}
像这样在子类中添加一个int age=10; 就把父类的age覆盖掉了,结果就没问题了。
继承过后子类中就有了age这个属性,用int age覆盖掉原来的定义,怎么不叫多态。。只是不提倡属性的覆盖罢了。追问

厉害
好像真的是这样子啊
本人菜鸟,想再请教一下,新建了一个son,它的区域中是不是也有father,然后重写的方法,写在father外,son中的区域,然后如果age不重写,无论super,this直接就引用了father的属性?
然后属性的覆盖,是不是不能称之为重写呐?

追答

方法在内存的存放不清楚,反正重写的方法是属于子类自己的,父类看不到。继承过后如果没有覆盖,那么子类从父类继承来的变量与父类的变量指向同一个域,覆盖之后。系统会给子类变量重新开辟一个存储空间。

温馨提示:答案为网友推荐,仅供参考
第1个回答  2012-04-03
属性的调用不存在多态,也就是
super.age = 11;
this.age = 10;
指定的是同一个age追问

确实不存在多态
那子类无法调用父类属性?
请问内存空间里,父类和子类的属性就是一个区域吗?
这个问题很纠结

追答

子类和父类的属性是同一个东西,调用自己的跟调用父类的没区别。可以理解为同一个内存空间。

追问

不好意思,想刨根问底,我觉得怎么理解是其次,想知道内存里实际的分配是咋样的?这很复杂吗?

追答

他们指的是同一块内存,所以改一个就都改了。数据是在堆上的。。。

本回答被网友采纳
第2个回答  2012-04-03
你这个程序创建了两个父类和一个子类
其中一个父类的创建是系统创建子类时自动创建的,你看不见,也不知道他在那 假设名字为“F”
F中的age你已经改变了
另一个父类就是 Father father = (Father)son1;
F与father 是指向两个对象啊
第3个回答  2013-01-08
只有在子类中才可以调用super.
相似回答