您好,登錄后才能下訂單哦!
JAVA 枚舉單例模式及源碼分析的實例詳解
單例模式的實現(xiàn)有很多種,網(wǎng)上也分析了如今實現(xiàn)單利模式最好用枚舉,好處不外乎三點:
1.線程安全
2.不會因為序列化而產(chǎn)生新實例
3.防止反射攻擊但是貌似沒有一篇文章解釋ENUM單例如何實現(xiàn)了上述三點,請高手解釋一下這三點:
關于第一點線程安全,從反編譯后的類源碼中可以看出也是通過類加載機制保證的,應該是這樣吧(解決)
關于第二點序列化問題,有一篇文章說枚舉類自己實現(xiàn)了readResolve()方法,所以抗序列化,這個方法是當前類自己實現(xiàn)的(解決)
關于第三點反射攻擊,我有自己試著反射攻擊了以下,不過報錯了...看了下方的反編譯類源碼,明白了,因為單例類的修飾是abstract的,所以沒法實例化。(解決)
以下是我寫的一個枚舉單例,以及其class文件反編譯過后的類
枚舉單例
public enum Singleton { INSTANCE { @Override protected void read() { System.out.println("read"); } @Override protected void write() { System.out.println("write"); } }; protected abstract void read(); protected abstract void write(); }
反編譯過后還原的類
public abstract class Singleton extends Enum { private Singleton(String s, int i) { super(s, i); } protected abstract void read(); protected abstract void write(); public static Singleton[] values() { Singleton asingleton[]; int i; Singleton asingleton1[]; System.arraycopy(asingleton = ENUM$VALUES, 0, asingleton1 = new Singleton[i = asingleton.length], 0, i); return asingleton1; } public static Singleton valueOf(String s) { return (Singleton)Enum.valueOf(singleton/Singleton, s); } Singleton(String s, int i, Singleton singleton) { this(s, i); } public static final Singleton INSTANCE; private static final Singleton ENUM$VALUES[]; static { INSTANCE = new Singleton("INSTANCE", 0) { protected void read() { System.out.println("read"); } protected void write() { System.out.println("write"); } }; ENUM$VALUES = (new Singleton[] { INSTANCE }); } }
以上就是JAVA 枚舉單例模式及源碼分析,如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。