java 板


LINE

※ 引述《NewSpec (新規格)》之銘言: : 標題: [問題] 為什麼存取final欄位不會觸發initializer : 時間: Mon Feb 10 16:22:18 2014 : : : 直接看例子 : : // Test.java : public class Test : { : public static final int CONST = 10; : : static { : System.out.println("initializer in Test"); : } : } : : // Main.java : public class Main : { : public static void main(String[] args){ : System.out.println("Main.main() is called."); : System.out.println(Test.CONST); : } : } : : // Output: : Main.main() is called. : 10 : : 但去掉Test.CONST宣告中的final後, output就成為了: : Main.main() is called. : initializer in Test : 10 : : 雖然說Java語言規格中有說明到: 對類別或界面中的常數的存取不會觸發初始化 : (§12.4.1) : : 但我還是想了解一下為什麼要做這樣的限制 : : 是效能的考量嗎? 多謝 : : : -- :



※ 發信站: 批踢踢實業坊(ptt.cc)
: ◆ From: 59.120.134.11 : 推 PsMonkey:不需要執行 static block 不是很好嗎? 反正值都確定了 02/10 17:28 : → sbrhsieh:只有 primitive type 與 String type final field 是這樣 02/10 19:59 : → sbrhsieh:其初始值是直接存在 class bytecode 裡。 02/10 20:01 : → NewSpec:got it! 謝謝解惑! 02/10 20:14 : → sbrhsieh:我講得太過粗略,也不十分正確,補個文~~ 02/10 23:35 詳細的故事是 primitive 與 String type 之 static final field 的初始值若是 compile-time constant value:literal 或是可在編譯時求值(evaluate)的 expression etc..,那麼編譯器會把這已知的初始值放在 class bytecode 裡定義 該 field 的區段裡。 有這個機制後的一個 consequence 是影響到使用這一類的 static final field 的 client code。 以你文中的第一個例子來說,Main.java 裡有參考到 Test.CONST,編譯器載入 Test.class 檔後,可以得知 Test class 有個名為 CONST 的 static final field 與其初始值 10,這個初始值是載入 Test class 的 bytecode 後就可以得知, 不需要在 runtime 去 resolve Test class,於是編譯器進一步直接在產生 Main class 的 bytecode 時把參考到 Test.CONST 的地方換成常數值 10。 這樣子的 main method 與你例子中的 Main::main method 等效: public static void main(String[] args) { System.out.println("Main.main() is called."); System.out.println(10); } 也就是說當你去執行 Main class(的 main method)時,JVM 甚至沒有載入 Test.class,簡單的驗證方式是你可以把 Test.class 檔刪除,你依然可以執行 Main class 且產出相同的 output。 --



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 218.164.110.144 ※ 編輯: sbrhsieh 來自: 218.164.110.144 (02/11 00:45)
1F:→ NewSpec:推~ 02/11 01:09
2F:推 KeySabre:推 02/11 01:35
3F:推 gmoz:推~~~~~~~~~~ 02/11 10:53
4F:推 kewang:好文推! 02/11 13:14
5F:推 dream1124:推 02/11 19:04
6F:推 mrker:推 02/11 20:09
7F:推 gulesmoon:專業推XDD 02/12 08:39







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:e-shopping站內搜尋

TOP