Java中的枚舉類型存儲在Jvm運行期的那個區域?為什么單例模式用枚舉就完美解決了?
問題描述
Java中的枚舉類型是存儲在Java運行期的那個區域?為什么單例模式用枚舉就完美解決了?
枚舉的內存分配是發生在什么時候?初始化又是啥發生在什么時候?代碼中使用枚舉時候,發生了什么事情?
問題解答
回答1:Java中枚舉存在在Method Area(方法區)
public enum T { E1, E2}
上面這段代碼編譯后如下:
$ javap T.classCompiled from 'T.java'public final class io.zhudy.web.T extends java.lang.Enum<io.zhudy.web.T> { public static final io.zhudy.web.T E1; public static final io.zhudy.web.T E2; public static io.zhudy.web.T[] values(); public static io.zhudy.web.T valueOf(java.lang.String); static {};}
可以發現常量最后實際都是被編譯為靜態變量了,Java中靜態變量都是存儲在Method Area。
單例模式的目的是為了保證在內存中只存在唯一一個實例,而枚舉值是固定的剛好可以達到控制實例數的目的
那傳統的采用class實現單例與enum不同之處呢,在于使用使用class需要將constructor訪問級別設置為private如果還要防止reflect繞過訪問控制創建對象,還需要做額外處理如下:
public class T2 { public static final T2 INSTANCE = new T2(); private T2() {if (INSTANCE != null) { throw new AssertionError('實例已存在');} } public static void main(String[] args) throws Exception {Constructor c = T2.class.getDeclaredConstructor();Object o = c.newInstance();System.out.println(o); }}
相關文章:
1. docker-compose 為何找不到配置文件?2. boot2docker無法啟動3. docker images顯示的鏡像過多,狗眼被亮瞎了,怎么辦?4. java中返回一個對象,和輸出對像的值,意義在哪兒5. android - E/dalvikvm: Could not find class java.nio.file.Path,6. python - linux怎么在每天的凌晨2點執行一次這個log.py文件7. android - 哪位大神知道java后臺的api接口的對象傳到前端后輸入日期報錯,是什么情況?求大神指點8. mysql數據庫每次查詢是一條線程嗎?9. python是怎么實現過濾 #注釋代碼的?10. 請問一下各位老鳥 我一直在學習獨孤九賤 現在是在tp5 今天發現 這個系列視頻沒有實戰
