关于java子类中使用super为何不能调用父类属性的疑问 30
在子类使用super.age=11给父类age赋值,可打印super.age的结果不是11,而是子类的10,求解释!!!publicclassFatherSon{publ...
在子类使用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);
}
} 展开
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);
}
} 展开
4个回答
展开全部
你把打印的结果拿来看下 ,而且父类型指向子类型不需要强制转换。
楼下的,子类中的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覆盖掉原来的定义,怎么不叫多态。。只是不提倡属性的覆盖罢了。
楼下的,子类中的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的属性?
然后属性的覆盖,是不是不能称之为重写呐?
追答
方法在内存的存放不清楚,反正重写的方法是属于子类自己的,父类看不到。继承过后如果没有覆盖,那么子类从父类继承来的变量与父类的变量指向同一个域,覆盖之后。系统会给子类变量重新开辟一个存储空间。
展开全部
属性的调用不存在多态,也就是
super.age = 11;
this.age = 10;
指定的是同一个age
super.age = 11;
this.age = 10;
指定的是同一个age
更多追问追答
追问
确实不存在多态
那子类无法调用父类属性?
请问内存空间里,父类和子类的属性就是一个区域吗?
这个问题很纠结
追答
子类和父类的属性是同一个东西,调用自己的跟调用父类的没区别。可以理解为同一个内存空间。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你这个程序创建了两个父类和一个子类
其中一个父类的创建是系统创建子类时自动创建的,你看不见,也不知道他在那 假设名字为“F”
F中的age你已经改变了
另一个父类就是 Father father = (Father)son1;
F与father 是指向两个对象啊
其中一个父类的创建是系统创建子类时自动创建的,你看不见,也不知道他在那 假设名字为“F”
F中的age你已经改变了
另一个父类就是 Father father = (Father)son1;
F与father 是指向两个对象啊
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
只有在子类中才可以调用super.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询