国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

設(shè)計(jì)模式-創(chuàng)建型模式-單例模式

這篇具有很好參考價(jià)值的文章主要介紹了設(shè)計(jì)模式-創(chuàng)建型模式-單例模式。希望對大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

0 引言

創(chuàng)建型模式(Creational Pattern)關(guān)注對象的創(chuàng)建過程,是一類最常用的設(shè)計(jì)模式,每個(gè)創(chuàng)建型模式都通過采用不同的解決方案來回答3個(gè)問題:創(chuàng)建什么(What),由誰創(chuàng)建(Who)和何時(shí)創(chuàng)建(When)。

設(shè)計(jì)模式-創(chuàng)建型模式-單例模式,設(shè)計(jì)模式,設(shè)計(jì)模式,單例模式

?1 單例模式

單例模式有3個(gè)要點(diǎn):①某個(gè)類只能有一個(gè)實(shí)例;②它必須自行創(chuàng)建這個(gè)實(shí)例;③它必須自行向整個(gè)系統(tǒng)提供這個(gè)實(shí)例。

單例模式(Singleton),保證一個(gè)類僅有一個(gè)實(shí)例,并提供一個(gè)訪問它的全局訪問點(diǎn)。[DP]

1.1 餓漢單例模式

?在類加載的時(shí)候就已經(jīng)實(shí)例化,并且創(chuàng)建單例對象,以后直接使用即可。這種模式下,類加載較慢,但獲取對象的速度快,且線程安全。

public class HungrySingleton {
    // 在類加載時(shí)就已經(jīng)完成了實(shí)例的初始化
    private static final HungrySingleton instance = new HungrySingleton();

    // 構(gòu)造器私有,防止外部通過new關(guān)鍵字創(chuàng)建對象
    private HungrySingleton() {}

    // 提供全局訪問點(diǎn)
    public static HungrySingleton getInstance() {
        return instance;
    }

    // 如果需要,可以添加其他方法或?qū)傩?    public void showMessage() {
        System.out.println("This is an instance of HungrySingleton.");
    }

    public static void main(String[] args) {
        // 獲取單例對象
        HungrySingleton instance1 = HungrySingleton.getInstance();
        HungrySingleton instance2 = HungrySingleton.getInstance();

        // 輸出實(shí)例,驗(yàn)證是否為同一個(gè)對象
        System.out.println(instance1);
        System.out.println(instance2);

        // 驗(yàn)證是否為同一個(gè)對象的引用
        System.out.println(instance1 == instance2);

        // 調(diào)用實(shí)例方法
        instance1.showMessage();
    }
}

1.2 懶漢單例模式

一開始不會實(shí)例化,什么時(shí)候用就什么時(shí)候進(jìn)行實(shí)例化。這種模式下,類加載較快,但獲取對象的速度稍慢,且可能在多線程情況下出現(xiàn)線程安全問題。

?存在線程安全問題,

public class LazySingleton {
    // 私有靜態(tài)實(shí)例,初始化為null
    private static LazySingleton instance = null;

    // 私有構(gòu)造方法,防止外部通過new關(guān)鍵字創(chuàng)建對象
    private LazySingleton() {}

    // 提供全局訪問點(diǎn)
    public static  LazySingleton getInstance() {
        if (instance == null) {
            instance = new LazySingleton();
        }
        return instance;
    }

    // 如果需要,可以添加其他方法或?qū)傩?    public void showMessage() {
        System.out.println("This is an instance of LazySingleton.");
    }

    public static void main(String[] args) {
        // 獲取單例對象
        LazySingleton instance1 = LazySingleton.getInstance();

        // 調(diào)用實(shí)例方法
        instance1.showMessage();
    }
}

加鎖,

public class LazySingleton {
    // 私有靜態(tài)實(shí)例,初始化為null
    private static LazySingleton instance = null;

    // 私有構(gòu)造方法,防止外部通過new關(guān)鍵字創(chuàng)建對象
    private LazySingleton() {}

    // 同步方法,提供全局訪問點(diǎn)
    public static synchronized LazySingleton getInstance() {
        if (instance == null) {
            instance = new LazySingleton();
        }
        return instance;
    }

    // 如果需要,可以添加其他方法或?qū)傩?    public void showMessage() {
        System.out.println("This is an instance of LazySingleton.");
    }

    public static void main(String[] args) {
        // 獲取單例對象
        LazySingleton instance1 = LazySingleton.getInstance();
        LazySingleton instance2 = LazySingleton.getInstance();

        // 輸出實(shí)例,驗(yàn)證是否為同一個(gè)對象
        System.out.println(instance1);
        System.out.println(instance2);

        // 驗(yàn)證是否為同一個(gè)對象的引用
        System.out.println(instance1 == instance2);

        // 調(diào)用實(shí)例方法
        instance1.showMessage();
    }
}

然而,同步方法會導(dǎo)致性能下降,因?yàn)槊看握{(diào)用getInstance()方法時(shí)都需要進(jìn)行同步。為了解決這個(gè)問題,可以使用雙重校驗(yàn)鎖(Double-Checked Locking,DCL)來實(shí)現(xiàn)更高效的懶漢單例模式:現(xiàn)在這樣,我們不用讓線程每次都加鎖,而只是在實(shí)例未被創(chuàng)建的時(shí)候再加鎖處理。同時(shí)也能保證多線程的安全。這種做法被稱為Double-Check Locking(雙重鎖定)。

public class LazySingletonWithDCL {
    // volatile關(guān)鍵字確保instance在多線程環(huán)境下被正確初始化
    private static volatile LazySingletonWithDCL instance = null;

    // 私有構(gòu)造方法,防止外部通過new關(guān)鍵字創(chuàng)建對象
    private LazySingletonWithDCL() {}

    // 提供全局訪問點(diǎn)
    public static LazySingletonWithDCL getInstance() {
        if (instance == null) {
            // 第一次檢查
            synchronized (LazySingletonWithDCL.class) {
                if (instance == null) {
                    // 第二次檢查
                    instance = new LazySingletonWithDCL();
                }
            }
        }
        return instance;
    }

    // 如果需要,可以添加其他方法或?qū)傩?    public void showMessage() {
        System.out.println("This is an instance of LazySingletonWithDCL.");
    }

    public static void main(String[] args) {
        // 獲取單例對象
        LazySingletonWithDCL instance1 = LazySingletonWithDCL.getInstance();
        LazySingletonWithDCL instance2 = LazySingletonWithDCL.getInstance();

        // 輸出實(shí)例,驗(yàn)證是否為同一個(gè)對象
        System.out.println(instance1);
        System.out.println(instance2);

        // 驗(yàn)證是否為同一個(gè)對象的引用
        System.out.println(instance1 == instance2);

        // 調(diào)用實(shí)例方法
        instance1.showMessage();
    }
}

使用內(nèi)部靜態(tài)類來實(shí)現(xiàn)單例模式,這種方式的特點(diǎn)是利用了類加載機(jī)制來保證初始化實(shí)例時(shí)只有一個(gè)實(shí)例被創(chuàng)建,并且由于JVM的類加載機(jī)制,這種方式是線程安全的。只適合java。文章來源地址http://www.zghlxwxcb.cn/news/detail-836031.html

public class Singleton {
    // 私有構(gòu)造方法,防止外部通過new關(guān)鍵字創(chuàng)建對象
    private Singleton() {}

    // 靜態(tài)內(nèi)部類,持有單例對象
    private static class SingletonHolder {
        // 靜態(tài)初始化器,由JVM保證線程安全
        private static final Singleton INSTANCE = new Singleton();
    }

    // 提供全局訪問點(diǎn)
    public static Singleton getInstance() {
        return SingletonHolder.INSTANCE;
    }

    // 如果需要,可以添加其他方法或?qū)傩?    public void showMessage() {
        System.out.println("This is an instance of Singleton.");
    }

    public static void main(String[] args) {
        // 獲取單例對象
        Singleton instance1 = Singleton.getInstance();
        Singleton instance2 = Singleton.getInstance();

        // 輸出實(shí)例,驗(yàn)證是否為同一個(gè)對象
        System.out.println(instance1);
        System.out.println(instance2);

        // 驗(yàn)證是否為同一個(gè)對象的引用
        System.out.println(instance1 == instance2);

        // 調(diào)用實(shí)例方法
        instance1.showMessage();
    }
}

到了這里,關(guān)于設(shè)計(jì)模式-創(chuàng)建型模式-單例模式的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 學(xué)習(xí)筆記-設(shè)計(jì)模式-創(chuàng)建型模式-單例模式

    一個(gè)類只有一個(gè)實(shí)例,并提供一個(gè)全局訪問此實(shí)例的點(diǎn),哪怕多線程同時(shí)訪問。 單例模式主要解決了 一個(gè)全局使用的類被頻繁的創(chuàng)建和消費(fèi) 的問題。 單例模式的案例場景 數(shù)據(jù)庫的連接池不會反復(fù)創(chuàng)建 spring中一個(gè)單例模式bean的生成和使用 在我們平常的代碼中需要設(shè)置全局

    2024年02月08日
    瀏覽(18)
  • 【地鐵上的設(shè)計(jì)模式】--創(chuàng)建型模式:單例模式(五)--枚舉單例

    什么是枚舉單例 枚舉單例是指使用枚舉類型來實(shí)現(xiàn)單例模式,它是單例模式中最簡單、最安全的一種實(shí)現(xiàn)方式。在枚舉類型中定義的枚舉值只會被實(shí)例化一次,即保證了全局唯一的實(shí)例,而且實(shí)現(xiàn)簡單、線程安全、防止反射攻擊、支持序列化等。 如何實(shí)現(xiàn)枚舉單例 實(shí)現(xiàn)枚舉

    2023年04月25日
    瀏覽(20)
  • 設(shè)計(jì)模式-創(chuàng)建型模式(單例、工廠、建造、原型)

    設(shè)計(jì)模式:軟件設(shè)計(jì)中普遍存在(反復(fù)出現(xiàn))的各種問題,所提出的解決方案。 面向?qū)ο笕筇匦裕悍庋b、繼承、多態(tài)。 面向?qū)ο笤O(shè)計(jì)的SOLID原則: (1)開放封閉原則:一個(gè)軟件實(shí)體如類、模塊和函數(shù)應(yīng)該對擴(kuò)展開放,對修改關(guān)閉。即軟件實(shí)體應(yīng)盡量在不修改原有代碼的情

    2024年02月08日
    瀏覽(28)
  • c#設(shè)計(jì)模式-創(chuàng)建型模式 之 單例模式

    目錄 前言: 優(yōu)點(diǎn): 缺點(diǎn): 餓漢式(靜態(tài)變量方式) 懶漢式(線程不安全) 懶漢式(雙重檢查鎖定) 推薦方式Lazy 總結(jié): 這種模式涉及到一個(gè)單一的類,該類負(fù)責(zé)創(chuàng)建自己的對象,同時(shí)確保只有單個(gè)對象被創(chuàng)建。這個(gè)類提供 了一種訪問其唯一的對象的方式,可以直接訪問,

    2024年02月13日
    瀏覽(31)
  • GO設(shè)計(jì)模式——4、單例模式(創(chuàng)建型)

    目錄 單例模式(Singleton Pattern)?? 優(yōu)缺點(diǎn) 使用場景 餓漢式和懶漢式單例模式 ????????單例模式(Singleton Pattern)是一個(gè)類 只允許創(chuàng)建一個(gè) 對象(或者實(shí)例),那這個(gè)類就是一個(gè)單例類,這種設(shè)計(jì)模式就叫作單例設(shè)計(jì)模式,簡稱單例模式。單例模式的要點(diǎn)有三個(gè):一是

    2024年02月05日
    瀏覽(24)
  • C++設(shè)計(jì)模式創(chuàng)建型之單例模式

    一、概述 ? ? ? ? 單例模式也稱單態(tài)模式,是一種創(chuàng)建型模式,用于創(chuàng)建只能產(chǎn)生一個(gè)對象實(shí)例的類。例如,項(xiàng)目中只存在一個(gè)聲音管理系統(tǒng)、一個(gè)配置系統(tǒng)、一個(gè)文件管理系統(tǒng)、一個(gè)日志系統(tǒng)等,甚至如果吧整個(gè)Windows操作系統(tǒng)看成一個(gè)項(xiàng)目,那么其中只存在一個(gè)任務(wù)管理

    2024年02月14日
    瀏覽(29)
  • 深入理解設(shè)計(jì)模式-創(chuàng)建型之單例模式

    如果有些數(shù)據(jù)在系統(tǒng)中應(yīng)該且只能保存一份,那就應(yīng)該設(shè)計(jì)為單例類。 如:配置類:在系統(tǒng)中,我們只有一個(gè)配置文件,當(dāng)配置文件被加載到內(nèi)存之后,應(yīng)該被映射為一個(gè)唯一的【配置實(shí)例】,此時(shí)就可以使用單例,當(dāng)然也可以不用。 全局計(jì)數(shù)器:我們使用一個(gè)全局的計(jì)數(shù)

    2024年02月12日
    瀏覽(24)
  • 【Java 設(shè)計(jì)模式】創(chuàng)建型之單例模式

    【Java 設(shè)計(jì)模式】創(chuàng)建型之單例模式

    在軟件開發(fā)中,單例模式是一種常見的設(shè)計(jì)模式, 它確保一個(gè)類只有一個(gè)實(shí)例,并提供一個(gè)全局訪問點(diǎn) 。單例模式在需要控制某些資源,如數(shù)據(jù)庫連接池、線程池等共享資源的情況下非常有用。在本文中,我們將介紹 Java 設(shè)計(jì)模式中的單例模式,了解其實(shí)現(xiàn)方式、使用場景

    2024年01月18日
    瀏覽(26)
  • Java23種設(shè)計(jì)模式-創(chuàng)建型模式之單例模式

    單例模式 (Singleton Pattern):通過單例模式的方法創(chuàng)建的 類在當(dāng)前進(jìn)程中只有一個(gè)實(shí)例 (根據(jù)需要,也有可能一個(gè)線程中屬于單例,如:僅線程上下文內(nèi)使用同一個(gè)實(shí)例),該類負(fù)責(zé) 創(chuàng)建自己的對象 ,同時(shí) 確保只有單個(gè)對象 被創(chuàng)建。 注 : 1、單例類 只能 有 一個(gè)實(shí)例 。

    2024年04月26日
    瀏覽(27)
  • 《golang設(shè)計(jì)模式》第一部分·創(chuàng)建型模式-01-單例模式(Singleton)

    《golang設(shè)計(jì)模式》第一部分·創(chuàng)建型模式-01-單例模式(Singleton)

    指目標(biāo)類(Class)只有一個(gè)實(shí)例對象(Object),并且向使用該對象的客戶端提供訪問單例的全局方法。 保證類只有一個(gè)實(shí)例 有方法能讓外部訪問到該實(shí)例 懶漢式 在第一次調(diào)用單例對象時(shí)創(chuàng)建該對象,這樣可以避免不必要的資源浪費(fèi) 餓漢式 在程序啟動時(shí)就創(chuàng)建單例對象,這

    2024年02月14日
    瀏覽(23)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包