Hello World!
main.ConstructedDerivedClass:6.0
main.ConstructedDerivedClass:6.0
public class ConstructedDerivedClass extends ConstructedBase {
private static final double version = 6.0;
public static void main(String[] args) {
System.out.println("Hello World!");
ConstructedDerivedClass derivedClass = new ConstructedDerivedClass();
}
public ConstructedDerivedClass() {
showMyAttributes();
}
@Override
protected void showMyAttributes() {
System.out.println(this.getClass().getName() + ":" + version);
}
}
public class ConstructedBase {
private static final double version = 15.0;
public ConstructedBase() {
showMyAttributes();
}
protected void showMyAttributes() {
System.out.println(this.getClass().getName() + ":" + version);
}
}
我希望它只是显示一条线,该子类(ConstructedDerivedClass)。但相反,它打印出来两次。我知道一般情况下,你应该避免从构造函数中调用overriden方法,但我想亲自看看这是如何工作的。
实际上,我知道为什么版本在两行上都是'6.0' - 因为字段被声明为静态,当然静态字段是首先初始化的。但仍然不明白为什么两条线。
任何指导,将不胜感激。
2014-05-13
Omar D
+0
这可能是一个重复的(但我没有”但是即使是这样,这是一个写得很好的问题,它清楚地显示了你感兴趣的输出,以及完整的代码。做得好! –
+0
谢谢。这仍然是新的。这两个答案在下面有帮助。很难挑选一个。 –