我試著分析下哦:
很顯然,程序是從Main開始執行的,不過執行之前肯定是裝載了Parent類的.
當執行new Child();語句時,肯定也會去裝載Child類(記住,這是只是裝載,裝載的同時會完成類的靜態成員的初始化工作).這里是請求創建Child的實例,因為Child是Parent的子類,那么肯定是要去先去創建Parent的一個實例的,那么在這個過程中,就會執行了Child的覆蓋方法test(),這時,子類中的instanceValue還沒有被賦值.因為這時候還沒有進行Child的實例創建.
看一下我加入一些狀態的程序和執行結果哦.
程序清單:
public class Parent
{
public void test() {
System.out.println("In Parent Class.");
}
public Parent() {
System.out.println("In Parent Constructor");
test();
}
public static void main(String [] args) {
System.out.println("In Main Function.");
new Child();
}
}
class Child extends Parent {
private int instanceValue = 20;
public void test() {
System.out.println("In Child Class.");
System.out.println("instance value is: " + this.instanceValue);
}
public Child() {
System.out.println("In Child Constructor.");
}
}
執行結果(主要是看執行順序哦):
In Main Function.
In Parent Constructor
In Child Class.
instance value is: 0
In Child Constructor.
嘿嘿,應該懂了吧!~ 你可以試著把instanceValue的修飾符改為static試試哦.
回復 更多評論