ringa_lee
首先第一個:你在定義A變數時,就沒有賦初值,所以A為NULL,然後得到B自然就是this is null然後第二個:public static void main,編譯器在編譯這段程式碼時a,b先被main函數引用,你再更改a,a倒是被更改了,但b還是那個b,永遠都是this is null。你需要明白靜態函數運作的過程的意義。你的B沒有動態被set,當然得到的就算那個靜態b,而不會被動態編譯。
這是關於JVM的類別初始化機制吧,字節碼轉為運行物件的三個過程裝載,連接,初始化。 。 。其中連接的準備過程會給a一個預設值null,因為StaticTest 具有main方法,被設定為JVM 啟動時的啟動類別會執行主動調用,進行類別的初始化,執行這兩行程式碼private static String a;private static String b = "this is " + a;所以b=this is null
首先第一個:你在定義A變數時,就沒有賦初值,所以A為NULL,然後得到B自然就是this is null
然後第二個:public static void main,編譯器在編譯這段程式碼時a,b先被main函數引用,你再更改a,a倒是被更改了,但b還是那個b,永遠都是this is null。你需要明白靜態函數運作的過程的意義。你的B沒有動態被set,當然得到的就算那個靜態b,而不會被動態編譯。
這是關於JVM的類別初始化機制吧,字節碼轉為運行物件的三個過程裝載,連接,初始化。 。 。其中連接的準備過程會給a一個預設值null,因為StaticTest 具有main方法,被設定為JVM 啟動時的啟動類別會執行主動調用,進行類別的初始化,執行這兩行程式碼private static String a;private static String b = "this is " + a;所以b=this is null