單例模式:確保一個類只有一個實例,并提供一個全局訪問點。
1、懶漢模式:
public class singleton { PRivate static singleton mSingleton; private singleton(){} public static singleton getInstance(){ if (mSingleton == null) { mSingleton = new singleton(); } return mSingleton; }}通過singleton mSingleton = singleton.getInstance();來獲取singleton的實例。這種模式是在需要的時候才會創建,如果在多線程中使用,會導致創建多個實例,這時候需要用同步鎖來確保只有一個實例。
2、同步鎖模式:
public class singleton { private static singleton mSingleton; private singleton(){} public static synchronized singleton getInstance(){ if (mSingleton == null) { mSingleton = new singleton(); } return mSingleton; }}雖然同步鎖可以解決多個實例的問題,但是在使用過程中,每次調用實例,都需要同步,對程序的性能來說有很大影響,有沒有辦法解決這個問題呢,答案是肯定的,“雙重檢查加鎖”模式可以減少使用同步。
3、雙重檢查加鎖模式:
public class singleton { private static singleton mSingleton; private singleton(){} public static singleton getInstance(){ if (mSingleton == null) { synchronized (singleton.class) { if (mSingleton == null) { mSingleton = new singleton(); } } } return mSingleton; }}4、惡漢模式:
public class singleton { private static singleton mSingleton = new singleton(); private singleton(){} public static singleton getInstance(){ return mSingleton; }}Singleton實例在singleton類加載的時候就實例化,這種方式是最簡單的方式,并且不存在多個實例的情況,也沒有線程同步的問題,缺點是即使沒有使用該單例,它也會在類加載時被創建,浪費內存。
5、靜態內部類:
public class singleton { private static class singletonHolder{ private static singleton mSingleton = new singleton(); } private singleton(){} public static singleton getInstance(){ return singletonHolder.mSingleton; }}這種方式同樣利用了類加載機制來保證只創建一個instance實例。它與餓漢模式一樣,也是利用了類加載機制,因此不存在多線程并發的問題。不一樣的是,它是在內部類里面去創建對象實例。這樣的話,只要應用中不使用內部類,JVM就不會去加載這個單例類,也就不會創建單例對象,從而實現懶漢式的延遲加載。也就是說這種方式可以同時保證延遲加載和線程安全。
6、枚舉:
public enum singleton{ instance; private singleton(){}}在java中,為了強制只實例化一個對象,最好的方法是使用一個枚舉量。
新聞熱點
疑難解答