這篇文章帶給大家的內容是關於Java中具有繼承關係的類別及其物件初始化順序的程式碼範例,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。
先說結論
對於具有繼承關係的類,它們的類別和物件建構順序為:父類別的類別建構器() -> 子類別的類別構造器() -> 父類別成員變數的賦值和實例程式碼區塊-> 父類別的建構子->子類別成員變數的賦值和實例程式碼區塊-> 子類別的建構子。
實驗程式碼如下:
public class ExtensionTest { public static void main(String[] args) { new SubClass(); } } class SuperClass { { System.out.println("我是父类实例块"); } static { System.out.println("我是父类类构造块"); } public SuperClass() { System.out.println("我是父类构造函数块"); } } class SubClass extends SuperClass { { System.out.println("我是子类实例块"); } static { System.out.println("我是子类类构造块"); } public SubClass() { System.out.println("我是子类构造函数块"); } }
結果:
我是父類別建構塊
我是子類別建構塊
我是父類別實例區塊
我是父類別建構子區塊
我是子類別實例區塊
我是子類別建構子區塊
解釋:
類別建構區塊是初始化類的時候執行的,而初始化類別首先得載入類別(不載入類別進記憶體當然沒法初始化)。
類別實例區塊是放在該類別建構子最前面和父類別建構子之後執行的。因為子類別的建構函式呼叫之前,會先呼叫父類別的建構子。
基於上述兩條規則,我們再來看執行順序。
new SubClass()也就是要建構SubClass這個類別的一個對象,而要建構這個對象,首先必須把這個類別的描述、定義載入進記憶體(類別載入)。因此要先載入這個類別(不過此時還未初始化)。
載入完這個類別之後,想要建構這個類別的物件。但是此時這個類別的靜態變數還未被初始化,因此要先初始化這個類,但是初始化這個類別需要先初始化它的父類,因此此時就變成了,載入父類->初始化父類(呼叫靜態區塊,即類別建構塊)
->初始化子類別(呼叫靜態區塊,即類別建構塊)。
接著就可以建構這個類別的物件了,建構這個類別的物件之前,要先建構父類別對象,因此會先呼叫父類別的建構函數,而呼叫父類別建構子之前又會先呼叫父類的實例塊。
接著就到了子類別建構函數,然而執行之前一樣要先呼叫子類別的實例區塊,最後才是子類別的建構函數的函數體。
##
java中具有繼承順序中具有繼承順序上的物件上序列順序上包含順序
#################################’’>初始化符號### java############ 34 次閱讀 · 作用時完成 5 分鐘閱讀 於 5 分鐘 ################################################################################################################################################################################################################### ###0#### ###
# # # # # #
先說結論
對於具有繼承關係的類,它們的類別和物件建構順序為:父類的類別建構器() -> ; 子類別的類別建構器() -> 父類別成員變數的賦值與實例程式碼區塊-> 父類別的建構子-> 子類別成員變數的賦值和實例程式碼區塊-> 子類別的建構函數。
實驗程式碼如下:
public class ExtensionTest { public static void main(String[] args) { new SubClass(); } } class SuperClass { { System.out.println("我是父类实例块"); } static { System.out.println("我是父类类构造块"); } public SuperClass() { System.out.println("我是父类构造函数块"); } } class SubClass extends SuperClass { { System.out.println("我是子类实例块"); } static { System.out.println("我是子类类构造块"); } public SubClass() { System.out.println("我是子类构造函数块"); } }
結果:
我是父類別建構塊
我是子類別建構塊
我是父類別實例區塊
我是父類別建構子區塊
我是子類別實例區塊
我是子類別建構子區塊
解釋:
類別建構區塊是初始化類的時候執行的,而初始化類別首先得載入類別(不載入類別進記憶體當然沒法初始化)。
類別實例區塊是放在該類別建構子最前面和父類別建構子之後執行的。因為子類別的建構函式呼叫之前,會先呼叫父類別的建構子。
基於上述兩條規則,我們再來看執行順序。
new SubClass()也就是要建構SubClass這個類別的一個對象,而要建構這個對象,首先必須把這個類別的描述、定義載入進記憶體(類別載入)。因此要先載入這個類別(不過此時還未初始化)。
載入完這個類別之後,想要建構這個類別的物件。但是此時這個類別的靜態變數還未被初始化,因此要先初始化這個類,但是初始化這個類別需要先初始化它的父類,因此此時就變成了,載入父類->初始化父類(呼叫靜態區塊,即類別建構塊)
->初始化子類別(呼叫靜態區塊,即類別建構塊)。
接著就可以建構這個類別的物件了,建構這個類別的物件之前,要先建構父類別對象,因此會先呼叫父類別的建構函數,而呼叫父類別建構子之前又會先呼叫父類的實例塊。
接著就到了子類別建構函數,然而執行之前一樣要先呼叫子類別的實例區塊,最後才是子類別的建構函數的函數體。
#你可能感興趣的
以上是Java中具有繼承關係的類別及其物件初始化順序的程式碼範例的詳細內容。更多資訊請關注PHP中文網其他相關文章!