您好,登錄后才能下訂單哦!
這篇文章主要介紹了Android如何實現單例模式,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
public class SingletionStarving { private static final SingletionStarving mInstance = new SingletionStarving(); private SingletionStarving() { } public static SingletionStarving getInstance() { return mInstance; } }
構造函數用private修飾,外部無法訪問
聲明靜態對象時就初始化
static關鍵字修飾,靜態變量,存儲在內存中,只有一份數據。
final關鍵字,只初始化一次,所以mInstance實例只有一個。
public class SingletionSlacker { private static SingletionSlacker mInstance; private SingletionSlacker() {} public static synchronized SingletionSlacker getInstance() { if (mInstance == null) { mInstance = new SingletionSlacker(); } return mInstance; } }
構造函數用private修飾,外部無法訪問
使用的時候即調用getInstance的時候才初始化
static關鍵字修飾,靜態變量,存儲在內存中,只有一份數據。
synchronized線程安全,多線程情況下單例的唯一性
缺點:沒次調用getInstance都會同步一次,浪費資源
網上建議和使用最多的方法
public class Singletion { private static Singletion mInstance; private Singletion() {} public static Singletion getmInstance() { if (mInstance == null) { synchronized (Singletion.class) { if (mInstance == null) { mInstance = new Singletion (); } } } return mInstance; } }
構造函數用private修飾,外部無法訪問
使用的時候即調用getInstance的時候才初始化
static關鍵字修飾,靜態變量,存儲在內存中,只有一份數據
synchronized線程安全,多線程情況下單例的唯一性
兩次判斷空,避免多次同步(synchronized)
缺點
private static Singletion mInstance; private Singletion() {} public static Singletion getmInstance() {}
由于jvm特性,允許亂序執行,上面三句代碼順序不定,那么就可能出現失效的問題。
步驟一、倘若A線程執行getmInstance(),還沒執行構造方法Singletion()
步驟二、此時B線程調用getmInstance()。因為A已經執行getmInstance(),所以mInstance不為空就直接獲取。
步驟三、由于B直接獲取,而真實情況是A線程構造方法還未執行,所以mInstance就為空了。
雖然此情況發生概率較小,但也是一種情況。為了解決這種情況,java1.6開始加入volatile關鍵字
private volatile static Singletion mInstance;
這樣就避免了方式失效的情況。雖然會volatile消耗一些性能,所以最佳寫法
public class Singletion { private volatile static Singletion mInstance; private Singletion () {} public static Singletion getmInstance() { if (mInstance == null) { synchronized (Singletion.class) { if (mInstance == null) { mInstance = new Singletion(); } } } return mInstance; } }
雖然volatile讓方式完美,但是沒有volatile關鍵字的寫法基本能滿足絕大部分情況。除非你要運行在高并發,或者java1.6之前的代碼中。
public class SingletionInternalClass { private SingletionInternalClass() {} public static SingletionInternalClass getInstance() { return SingletionInternalClassHolder.instance; } private static class SingletionInternalClassHolder { private static final SingletionInternalClass instance = new SingletionInternalClass(); } }
構造函數用private修飾,外部無法訪問
使用的時候即調用getInstance的時候才初始化
調用getInstance才回去加載SingletionInternalClassHolder類,確保了線程安全,保證了單例的唯一性
單例模式不管用那種方式實現,核心思想都相同
1、構造函數私有化,通過一次靜態方法獲取一個唯一實例
2、線程安全
最后推薦使用文中**雙重鎖方式和靜態內部類的方式**來創建單例模式。
Android是一種基于Linux內核的自由及開放源代碼的操作系統,主要使用于移動設備,如智能手機和平板電腦,由美國Google公司和開放手機聯盟領導及開發。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“Android如何實現單例模式”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。