这段代码让我有点困惑
基类:
public class BaseClass {
public void g(){
System.out.print("g in BaseClass\n");
}
public void m(){
System.out.print("m in BaseClass\n");
g();
}
}
继承的类:
public class WhenInheriting extends BaseClass{
public void g(){
System.out.print("g in WhenInheriting\n");
super.g();
}
}
这是主要位置:
public class MainIsHere {
public static void main(String[]args){
WhenInheriting wi= new WhenInheriting();
wi.g();
wi.m();
}
}
结果:
- 继承时的 g
- 基类中的 g
- m 在基类中
- 继承时的 g
- 基类中的 g
所以,好吧。首先调用 WhenInheriting
中的 g()
,然后通过 super.g()
调用 BaseClass 的 g()
也称为。
当调用m()
时,会从其主体调用方法g()
。但与我预期的 g()
是来自 BaseClass 的方法不同,g()
结果是来自 WhenInheriting 类的方法。
我可以对此进行一些逻辑:也许当 m()
说打印并调用 g()
时,因为引用只知道一个 g( )
,即调用继承类中的方法g()
。
现在我想知道如何编写代码,以便当从 WhenInhereting
类调用 m()
时 g()
将通过它调用的是来自 BaseClass 的 g()
吗?
我尝试在 m()
中编写 super.g()
而不是仅在 g()
中编写,但这是不允许的。
最佳答案
这就是多态性的意义所在。该对象的具体类型是 WhenInheriting
,因此将调用的多态 g()
方法将始终是 WhenInheriting.g()
方法。
这就像真实的物体。假设您有一个 size()
为 20 的 Box,并创建一个 size()
为 40 的 BigBox 子类。假设我向您要一个盒子,而您把大盒子给我。它的 size()
将为 40。即使我将这个 BigBox 视为一个 Box,甚至不知道它是一个特殊的 Box,而实际上它是一个 BigBox。
如果您希望基类调用某个方法并确保子类不会重写它,那么它不应该是可重写的。因此它应该调用另一个私有(private)或最终的方法g2()
。
关于java - 从基类调用重新定义的方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20313568/