請問關(guān)于 Java static 變量的問題?
問題描述
public class StaticTest { private static String a; private static String b = 'this is ' + a; public static void main(String[] args) {a = 'test';// I think the result is this is test// but the result is this is null, why?System.out.println(b); } // // 我本以為輸出結(jié)果是 this is test // 沒想到輸出結(jié)果為 this is null, 這是什么原因}
問題解答
回答1:首先第一個:你在定義A變量時,就沒有賦初值,所以A為NULL,然后得到B自然就是this is null然后第二個:public static void main,編譯器在編譯這段代碼時a,b先被main函數(shù)引用,你再更改a,a倒是被更改了,但b還是那個b,永遠都是this is null。你需要明白靜態(tài)函數(shù)運行的過程的意義。你的B沒有動態(tài)被set,當(dāng)然獲得的就算那個靜態(tài)b,而不會被動態(tài)編譯。
回答2:這是關(guān)于JVM的類初始化機制吧,字節(jié)碼轉(zhuǎn)為運行對象的三個過程裝載,連接,初始化。。。其中連接的準(zhǔn)備過程會給a賦予默認(rèn)值null,因為 StaticTest 具有main方法,被設(shè)定為 JVM 啟動時的啟動類會執(zhí)行主動調(diào)用,進行類的初始化,執(zhí)行這兩行代碼 private static String a;private static String b = 'this is ' + a;所以b=this is null
相關(guān)文章:
1. mysql在限制條件下篩選某列數(shù)據(jù)相同的值2. php - 生產(chǎn)環(huán)境下,給MySQL添加索引,修改表結(jié)構(gòu)操作,如何才能讓線上業(yè)務(wù)不受影響?3. mysql - Sql union 操作4. mysql - 僅僅只是把單引號與反斜杠轉(zhuǎn)義不用prepare statement能否避免sql注入?5. java - Mybatis 數(shù)據(jù)庫多表關(guān)聯(lián)分頁的問題6. mysql主主同步,從庫不同步應(yīng)該怎么解決?7. mysql - 拖拽重排序后怎么插入數(shù)據(jù)庫?8. 新入手layuiadmin,部署到tp中。想用php自已寫一個后臺管理系統(tǒng)。9. android - 安卓做前端,PHP做后臺服務(wù)器 有什么需要注意的?10. mysql 獲取時間函數(shù)unix_timestamp 問題?
