亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android 單例模式的四種實(shí)現(xiàn)方式

 更新時(shí)間:2021年05月22日 11:52:38   作者:Android開發(fā)編程  
單例模式作為設(shè)計(jì)模式之一,使用場景非常多。本文講述了Android實(shí)現(xiàn)單例模式的幾種方式

一.餓漢式

public class SingletionStarving {

    private static final SingletionStarving mInstance = new SingletionStarving();

    private SingletionStarving() {

    }

    public static SingletionStarving getInstance() {
        return mInstance;
    }
}
  • 構(gòu)造函數(shù)用private修飾,外部無法訪問
  • 聲明靜態(tài)對(duì)象時(shí)就初始化
  • static關(guān)鍵字修飾,靜態(tài)變量,存儲(chǔ)在內(nèi)存中,只有一份數(shù)據(jù)。
  • final關(guān)鍵字,只初始化一次,所以mInstance實(shí)例只有一個(gè)。

二.懶漢式

public class SingletionSlacker {

    private static SingletionSlacker mInstance;

    private  SingletionSlacker() {}

    public static synchronized SingletionSlacker getInstance() {
        if (mInstance == null) {
            mInstance = new SingletionSlacker();
        }
        return mInstance;
    }
}
  • 構(gòu)造函數(shù)用private修飾,外部無法訪問
  • 使用的時(shí)候即調(diào)用getInstance的時(shí)候才初始化
  • static關(guān)鍵字修飾,靜態(tài)變量,存儲(chǔ)在內(nèi)存中,只有一份數(shù)據(jù)。
  • synchronized線程安全,多線程情況下單例的唯一性
  • 缺點(diǎn):沒次調(diào)用getInstance都會(huì)同步一次,浪費(fèi)資源

三.雙重檢查加鎖方式

網(wǎng)上建議和使用最多的方法

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;
    }
}
  • 構(gòu)造函數(shù)用private修飾,外部無法訪問
  • 使用的時(shí)候即調(diào)用getInstance的時(shí)候才初始化
  • static關(guān)鍵字修飾,靜態(tài)變量,存儲(chǔ)在內(nèi)存中,只有一份數(shù)據(jù)
  • synchronized線程安全,多線程情況下單例的唯一性
  • 兩次判斷空,避免多次同步(synchronized)

缺點(diǎn)

private static Singletion mInstance;
private Singletion() {}
public static Singletion getmInstance() {}

由于jvm特性,允許亂序執(zhí)行,上面三句代碼順序不定,那么就可能出現(xiàn)失效的問題。
步驟一、倘若A線程執(zhí)行g(shù)etmInstance(),還沒執(zhí)行構(gòu)造方法Singletion()
步驟二、此時(shí)B線程調(diào)用getmInstance()。因?yàn)锳已經(jīng)執(zhí)行g(shù)etmInstance(),所以mInstance不為空就直接獲取。
步驟三、由于B直接獲取,而真實(shí)情況是A線程構(gòu)造方法還未執(zhí)行,所以mInstance就為空了。
雖然此情況發(fā)生概率較小,但也是一種情況。為了解決這種情況,java1.6開始加入volatile關(guān)鍵字

private volatile static Singletion mInstance;

這樣就避免了方式失效的情況。雖然會(huì)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關(guān)鍵字的寫法基本能滿足絕大部分情況。除非你要運(yùn)行在高并發(fā),或者java1.6之前的代碼中。

四.靜態(tài)內(nèi)部類方式

public class SingletionInternalClass {

    private SingletionInternalClass() {}

    public static SingletionInternalClass getInstance() {
        return SingletionInternalClassHolder.instance;
    }

    private static class SingletionInternalClassHolder {
        private static final SingletionInternalClass instance = new SingletionInternalClass();
    }
}

構(gòu)造函數(shù)用private修飾,外部無法訪問

使用的時(shí)候即調(diào)用getInstance的時(shí)候才初始化

調(diào)用getInstance才回去加載SingletionInternalClassHolder類,確保了線程安全,保證了單例的唯一性

總結(jié)

單例模式不管用那種方式實(shí)現(xiàn),核心思想都相同
1、構(gòu)造函數(shù)私有化,通過一次靜態(tài)方法獲取一個(gè)唯一實(shí)例
2、線程安全

最后推薦使用文中**雙重鎖方式和靜態(tài)內(nèi)部類的方式**來創(chuàng)建單例模式。

以上就是Android 單例模式的四種實(shí)現(xiàn)方式的詳細(xì)內(nèi)容,更多關(guān)于Android 單例模式的實(shí)現(xiàn)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論