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. boot2docker無法啟動2. 關docker hub上有些鏡像的tag被標記““This image has vulnerabilities””3. docker-compose中volumes的問題4. javascript - mock.js可以存儲數據嗎5. nignx - docker內nginx 80端口被占用6. java - SSH框架中寫分頁時service層中不能注入分頁類7. docker安裝后出現Cannot connect to the Docker daemon.8. dockerfile - 為什么docker容器啟動不了?9. golang - 用IDE看docker源碼時的小問題10. docker api 開發的端口怎么獲取?

網公網安備