ts學設計模式: 第一篇: 單例模式

模式定義git

單例模式: 確保一個類只有一個實例, 而且提供一個全局訪問的方法, 屬於建立型模式。github

模式結構圖typescript

單例

代碼實現bash

  • 懶漢模式
1. 懶漢模式中單例是在須要的時候纔去建立的,若是單例已經建立,再次調用獲取接口將不會從新建立新的對象,而是直接返回以前建立的對象。

2. 若是某個單例使用的次數少,而且建立單例消耗的資源較多,那麼就須要實現單例的按需建立
複製代碼
namespace SingletonPattern {
    export class Singleton {
        private static singleton: Singleton;

        private constructor () {

        }

        public static getInstance () {
            if (Singleton.singleton === null) {
                Singleton.singleton = new Singleton();
            }
            return Singleton.singleton;
        }
    }
}

複製代碼

測試代碼:測試

/// <reference path="Singleton.ts" />
var s1 = SingletonPattern.Singleton.getInstance();
var s2 = SingletonPattern.Singleton.getInstance();
if (s1 === s2) {
    console.log('兩個實例相等');
}
else {
    console.log('兩個實例不等');
}
複製代碼
  • 餓漢模式
1. 餓漢模式在類加載的時候就對實例進行建立,實例在整個程序週期都存在。

2. 它的好處是隻在類加載的時候建立一次實例, 適合單例佔用內存比較小,在初始化時就會被用到的狀況

3. 它的缺點也很明顯,即便這個單例沒有用到也會被建立,並且在類加載以後就被建立,內存就被浪費了
複製代碼
namespace SingletonPattern {
    export class Singleton {
        private static singleton: Singleton = new Singleton;

        private constructor () {

        }

        public static getInstance () {
            return Singleton.singleton;
        }
    }
}

複製代碼

測試代碼不變。ui

關於命名空間這裏大體解釋下:spa

ts的命名空間能夠把代碼包裹起來,經過export關鍵字進行對外暴露被訪問的對象。

在命名空間外部須要經過"徹底限定名"來訪問暴露的對象。

經過reference註釋引用命名空間,便可經過「徹底限定名」進行訪問。

相同的命名空間能夠聲明在不一樣的文件中。
複製代碼

模式分析code

單例模式的目的: 確保只有一個類的實例出現, 並提供一個全局訪問的方法。cdn

組成:
- 私有構造方法, 確保用戶沒法經過new來建立實例
- 靜態私有成員變量singleton存儲惟一的實例
- 靜態公有方法getInstance(): 靜態實例的存在性並實例化
複製代碼

優勢對象

  • 提供了對惟一實例的受控訪問

缺點

  • 因爲單例模式中沒有抽象層, 不易擴展
  • 單例類的職責太重,在必定程度上違背了「單一職責原則」。由於單例類既充當了工廠角色,提供了工廠方法,同時又充當了產品角色,包含一些業務方法(單例的內容屬性)

參考資料

相關文章
相關標籤/搜索