父類: public class TestStatic { } 子類: public class TestExtendStatic extends TestStatic{ } 輸出如下: ========靜態(tài)程序塊====== ========子類靜態(tài)程序塊====== ========子類主方法========England ========方法體======== :父類中非靜態(tài)代碼塊 =========構(gòu)造方法======== :父類構(gòu)造方法 ========無名稱方法體======== :子類中非靜態(tài)代碼塊 =========子類構(gòu)造方法======== :子類構(gòu)造方法 ========子類測試方法========= :子類測試方法 執(zhí)行順序: 父類靜態(tài)變量以及靜態(tài)程序塊 --- 子類的靜態(tài)變量以及靜態(tài)程序塊 --- 父類非靜態(tài)代碼塊 --- 父類中構(gòu)造方法 --- 子類中非靜態(tài)代碼塊 --- 子類中構(gòu)造方法 --- 法。 只要是用new 創(chuàng)建對象,分配了內(nèi)存空間,不管是將引用賦給上轉(zhuǎn)型對象,還是賦給子類對象,上面方法都必須執(zhí)行。 即:TestStatic ts = new TestExtendStatic();// 上轉(zhuǎn)型對象 上面加粗程序都會執(zhí)行。 上面程序中 ts.test(); 如果將子類中 main 方法該成如下: public static void main(String[] args){ 輸出: ========靜態(tài)程序塊====== ========子類靜態(tài)程序塊====== 子類中靜態(tài)程序塊 ========子類主方法========England 子類中主方法 ========方法體======== =========構(gòu)造方法======== 父類中構(gòu)造方法 ========無名稱方法體======== 子類中非靜態(tài)程序塊 =========子類構(gòu)造方法======== 子類中構(gòu)造方法 ========子類測試方法========= 對象具體調(diào)用的方法 ------------------------- 靜態(tài)變量以及程序塊只執(zhí)行一次 ========方法體======== 父類中非靜態(tài)代碼塊 =========構(gòu)造方法======== 父類中構(gòu)造方法 ========無名稱方法體======== 子類中非靜態(tài)代碼塊 =========子類構(gòu)造方法======== 子類中構(gòu)造方法 ========子類測試方法========= 如果將子類主方法 中更改為: TestStatic ts.test(); 輸出為: ========靜態(tài)程序塊====== 父類靜態(tài)程序塊 ========子類靜態(tài)程序塊====== 子類靜態(tài)程序塊【因為程序在子類中運行的,所以子類的靜態(tài)程序塊必須運行】 ========方法體======== =========構(gòu)造方法======== 父類構(gòu)造方法 ========測試方法========= 父類具體方法test() 如果將上述代碼放到父類中,就不會加載子類 靜態(tài)程序塊了。 通過上面 我們還可以發(fā)現(xiàn),靜態(tài)程序塊運行 是在主方法之前,非靜態(tài)程序塊運行是在主方法之后。 我在父類中 主方法中創(chuàng)建一個對象 調(diào)用test(),運行的結(jié)果: ========靜態(tài)程序塊====== 靜態(tài)代碼塊 總結(jié): 程序運行時(一個類中),會第一時間加載運行靜態(tài)代碼塊,一旦創(chuàng)建對象,就會執(zhí)行非靜態(tài)代碼塊以及無參構(gòu)造方法。 而在繼承中,程序運行時會先加載父類中靜態(tài)代碼塊 然后加載本身靜態(tài)代碼塊,一旦創(chuàng)建對象(運用子類構(gòu)造方法創(chuàng)建),就會調(diào)用父類非靜態(tài)代碼塊,父類構(gòu)造方法,然后就是本身 非靜態(tài)代碼塊,本身構(gòu)造方法。 |
|