今天就跟大家聊聊有關Java中反射修改類的常量值、靜態(tài)變量值,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
成都做網站、網站建設介紹好的網站是理念、設計和技術的結合。創(chuàng)新互聯擁有的網站設計理念、多方位的設計風格、經驗豐富的設計團隊。提供PC端+手機端網站建設,用營銷思維進行網站設計、采用先進技術開源代碼、注重用戶體驗與SEO基礎,將技術與創(chuàng)意整合到網站之中,以契合客戶的方式做到創(chuàng)意性的視覺化效果。class Bean{ private static final Integer INT_VALUE = 100; }
System.out.println(Bean.INT_VALUE); Field field = Bean.class.getField("INT_VALUE"); //將字段的訪問權限設為true:即去除private修飾符的影響 field.setAccessible(true); //去除final修飾符的影響,將字段設為可修改的 Field modifiersField = Field.class.getDeclaredField("modifiers"); modifiersField.setAccessible(true); modifiersField.setInt(field, field.getModifiers() & ~Modifier.FINAL); //把字段值設為200 field.set(null, 200); System.out.println(Bean.INT_VALUE);
100
200
看到測試結果說明我們的反射修改成功了。
class Bean{ public static int nums = 100; } System.out.println(Bean.nums); Field field = Bean.class.getField("nums"); field.set(null, 200); System.out.println(Bean.INT_VALUE);
測試結果修改成功。
100
200
注意到上述代碼的中的靜態(tài)常量類型是Integer,但是我們項目中實際需要修改的字段類型并不是包裝類型Integer,而是java的基本類型int。
當把常量的類型改成int之后。
class Bean{ private static final int INT_VALUE = 100;//把類型由Integer改成了int }
在其他代碼都不變的情況下,代碼輸出的結果竟然變成了詭異的:
100
100
而且在調試的過程中發(fā)現,在第二次輸出的時候,內存中的Bean.INT_VALUE是已經變成了200,但是System.out.println(Bean.INT_VALUE)輸出的結果卻依然時詭異的100?!
是反射失效了嗎?
又試了其他幾種類型,發(fā)現這種貌似失效的情會發(fā)生在int、long、boolean以及String這些基本類型上,而如果把類型改成Integer、Long、Boolean這種包裝類型,或者其他諸如Date、Object都不會出現失效的情況。
對于基本類型的靜態(tài)常量,JAVA在編譯的時候就會把代碼中對此常量中引用的地方替換成相應常量值。
參考:Modifying final fields in Java
即對于常量 public static final int maxFormatRecordsIndex = 100
if( index > maxFormatRecordsIndex ){ index = maxFormatRecordsIndex ; }
這段代碼在編譯的時候已經被java自動優(yōu)化成這樣的:
if( index > 100){ index = 100; }
所以在INT_VALUE是int類型的時候。
System.out.println(Bean.INT_VALUE);
編譯時會被優(yōu)化成下面這樣:
System.out.println(100);
所以,自然,無論怎么修改Boolean.INT_VALUE,System.out.println(Bean.INT_VALUE)都還是會依然固執(zhí)地輸出100了。
看完上述內容,你們對Java中反射修改類的常量值、靜態(tài)變量值有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注創(chuàng)新互聯行業(yè)資訊頻道,感謝大家的支持。