(一)單例模式

概念

單例模式屬于創(chuàng)建型模式,它提供了一種創(chuàng)建對(duì)象的最佳方式。這種模式涉及到一個(gè)單一的類,該類負(fù)責(zé)創(chuàng)建自己的對(duì)象,同時(shí)確保只有單個(gè)對(duì)象被創(chuàng)建。這個(gè)類提供了一種訪問(wèn)其唯一的對(duì)象的方式,可以直接訪問(wèn),不需要實(shí)例化該類的對(duì)象。

UML類圖

單例模式.png

餓漢式(靜態(tài)常量)

  • 優(yōu)點(diǎn):在類進(jìn)行裝載的時(shí)候就完成實(shí)例化,避免了線程同步問(wèn)題
  • 缺點(diǎn):如果沒有使用到類,該類也會(huì)被裝載進(jìn)來(lái),造成了內(nèi)存浪費(fèi)
public class Singleton1 {
    private final static  Singleton1 singleton1 =new Singleton1();
    private Singleton1(){
    }
    public static Singleton1 getInstence(){
        return singleton1;
    }
}

餓漢式(靜態(tài)代碼塊)

  • 優(yōu)缺點(diǎn)與餓漢式通過(guò)靜態(tài)變量一致
public class Singleton2 {
    private final static Singleton2 singleton2;
    static {
        singleton2=new Singleton2();
    }
    private Singleton2(){}
    public static Singleton2 getSingleton2(){
        return singleton2;
    }
}

懶加載(線程不安全)

  • 適用于單線程,多線程情況下,一個(gè)線程還未判斷結(jié)束時(shí),另一個(gè)線程就開始加載,會(huì)導(dǎo)致產(chǎn)生多個(gè)實(shí)例,線程不安全,無(wú)法保證單例
public class Singleton3 {
    private static Singleton3 singleton3;
    private Singleton3(){}
    public static Singleton3 getSingleton3(){
        if (null==singleton3){
            singleton3=new Singleton3();
        }
        return singleton3;
    }
}

懶漢式(線程安全)

  • 優(yōu)點(diǎn):線程安全
  • 缺點(diǎn):方法同步,效率低,每次調(diào)用該方法時(shí),都要進(jìn)行線程同步
public class Singleton4 {
    private static Singleton4 singleton4;
    private Singleton4(){}
    public static synchronized Singleton4 getSingleton4(){
        if (null==singleton4){
            singleton4=new Singleton4();
        }
        return singleton4;
    }
}

懶加載(同步代碼塊)

  • 無(wú)實(shí)際意義,在多線程環(huán)境下,當(dāng)多個(gè)線程同時(shí)進(jìn)入到if判斷中,會(huì)造成線程不安全
public class Singleton5 {
    private static Singleton5 singleton5;
    private Singleton5(){}
    public static Singleton5 getSingleton4(){
        if (null==singleton5){
            synchronized (Singleton5.class){
                singleton5=new Singleton5();
            }
        }
        return singleton5;
    }
}

懶加載(雙重檢查機(jī)制)

  • 優(yōu)點(diǎn):解決了線程安全問(wèn)題,也解決了效率問(wèn)題;
public class Singleton6 {
    //volatile防止指令重排序問(wèn)題,并且能將數(shù)據(jù)在主內(nèi)存中修改
    private static volatile Singleton6 singleton6;
    private Singleton6(){}
    public static Singleton6 getSingleton4(){
        if (null==singleton6){
            synchronized (Singleton5.class){
                if (null==singleton6){
                    singleton6=new Singleton6();
                }
            }
        }
        return singleton6;
    }
}

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

  • 靜態(tài)內(nèi)部類(Singleton)在外部類(Singleton7)加載時(shí)并不會(huì)將其加載出來(lái),只有使用到靜態(tài)內(nèi)部類時(shí)才會(huì)加載,
  • 類的靜態(tài)屬性只會(huì)在第一次加載類的時(shí)候初始化,jvm保證了線程的安全性
public class Singleton7 {
    private static Singleton7 singleton7;
    private Singleton7(){}
    //靜態(tài)內(nèi)部類
    private static class Singleton{
        private final static Singleton7 singleton7=new Singleton7();
    }
    public static  Singleton7 getSingleton7(){
        return Singleton.singleton7;
    }
}

枚舉類方式

  • 這種實(shí)現(xiàn)方式還沒有被廣泛采用,但這是實(shí)現(xiàn)單例模式的最佳方法。它更簡(jiǎn)潔,自動(dòng)支持序列化機(jī)制,絕對(duì)防止多次實(shí)例化,是線程安全,并不是懶加載。
public enum Singleton8 {
    INSTANCE;
    public void method(){
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容