gpt4 book ai didi

java - 为什么基类调用子类的方法?

转载 作者:行者123 更新时间:2023-12-01 18:31:39 24 4
gpt4 key购买 nike

我遇到一些如下代码:
基类:

public class BaseClass {
String name = "Base";

public BaseClass() {
printName();
}

public void printName() {
System.out.println(name + "——Base");
}
}

驱动类:

public class SubClass extends BaseClass {
String name = "Sub";

public SubClass() {
printName();
}

public void printName() {
System.out.println(name + "——Sub");
}

public static void main(String[] args) {
new SubClass();
}
}

运行代码时,输​​出为:

null——子
子——子

虽然应该是:

基地——基地
子——子

我想知道为什么 BaseClass 构造函数调用 SubClass 方法,有人可以解释一下吗?提前致谢。

最佳答案

第一行("null——Sub")是从调用SubClassprintName()的结果打印的BaseClass 构造函数。当从 BaseClass 构造函数调用 printName() 时,由于 SubClass 中有可用的重写方法,因此 printName() 被调用。

此时,由于 SubClass 构造函数尚未调用,因此 SubClassname 字段未定义,因此打印

第二行("Sub——Sub")是从SubClass调用printName()的结果打印出来的子类构造函数。这一次,实例字段被加载,因此 name 打印正确的值(即“Sub”)。

这里需要注意的是,两次都只调用 SubClassprintName() 方法。只是第一次(因为它是从 super 类构造函数调用的),其实例字段未定义,而第二次则定义了。

关于java - 为什么基类调用子类的方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23907276/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com