再論Singleton模式
Singleton模式可能是應用最廣泛的模式之一了, 但有些錯誤的應用。?Singleton的實現: 有兩種方式, 如下:
1. class Test { public static final Test instance = new Test(); private Test() {} }
?2. class Test { private static final Test instance = new Test(); private Test() {} public static Test getInstance() { return instance; } } 這兩種方法都要求構造器是私有的, 這樣就可以防止該類外的對象創建新的TEST對象。 但相對而言, 推薦使用第二種方法, 因為其更具有靈活性,當我們改變創建對象的方式的時候, 不需要改動客戶代碼。 第一種方法較第二種有一點完全可以忽略不計的效率的提高。
?但應避免如下代碼實現Singleton: class Test { private static Test singleton = null; private Test() {} public Test getSingleton() { if(singleton == null) { singleton = new Test(); } return singleton; } } 因為嚴格上講, 這并不能完全實現Singleton模式,而且會導致程序出錯, 這同著名的線程問題--DCL實效的原理是完全一樣的:
JVM創建對象的過程可以分為幾個步驟:創建空間, 把所有的變量賦值位默認值, 初始化。。。 當有兩個線程A和B同事進入該方法, A先執行, A創建Test實例的空間, 這時,因為CPU的指令流機制,時間片段正好輪到B線程, 這時B判斷singleton是否為NULL, 因為A已經為Test的實例分配了空間, 所以JVM認為實例已經創建了, B繼續執行, 更糟糕的是B調用了singleton, 這時因為他并沒有初始化完全, 所以拋出NullPointerException, 太糟糕了!
posted on 2006-10-30 14:10 Sheldon Sun 閱讀(189) 評論(0) 編輯 收藏