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. angular.js - angular內容過長展開收起效果2. docker網絡端口映射,沒有方便點的操作方法么?3. docker - 各位電腦上有多少個容器啊?容器一多,自己都搞混了,咋辦呢?4. docker綁定了nginx端口 外部訪問不到5. nignx - docker內nginx 80端口被占用6. fragment - android webView 返回后怎么禁止重新渲染?7. docker不顯示端口映射呢?8. php - mysql 模糊搜索問題9. java - 為什么此私有靜態變量能被訪問呢?10. php - 第三方支付平臺在很短時間內多次異步通知,訂單多次確認收款
