1 教科書裡的單例模式

2021-08-07 18:10:00 字數 2647 閱讀 5580

1 教科書裡的單例模式

我們都很清楚乙個簡單的單例模式該怎樣去實現:建構函式宣告為private或protect防止被外部函式例項化,內部儲存乙個private static的類指標儲存唯一的例項,例項的動作由乙個public的類方法代勞,該方法也返回單例類唯一的例項。

上**:  

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

classsingleton

private:

staticsingleton* p;

public:

staticsingleton* instance();

};

singleton* singleton::p = null;

singleton* singleton::instance()

這是乙個很棒的實現,簡單易懂。但這是乙個完美的實現嗎?不!該方法是執行緒不安全的,考慮兩個執行緒同時首次呼叫instance方法且同時檢測到p是null值,則兩個執行緒會同時構造乙個例項給p,這是嚴重的錯誤!同時,這也不是單例的唯一實現!

2 懶漢與餓漢

單例大約有兩種實現方法:懶漢與餓漢。

特點與選擇:

3 執行緒安全的懶漢實現

執行緒不安全,怎麼辦呢?最直觀的方法:加鎖。

class

singleton

private

:

static singleton*p;

public

:

static

pthread_mutex_t mutex;

static singleton*initance();

};pthread_mutex_t singleton::mutex;

singleton* singleton::p =null;

singleton*singleton::initance()

return

p;}

此方法也很容易實現,在instance函式裡定義乙個靜態的例項,也可以保證擁有唯一例項,在返回時只需要返回其指標就可以了。推薦這種實現方法,真得非常簡單。

class

singleton

public

:

static

pthread_mutex_t mutex;

static singleton*initance();

inta;

};pthread_mutex_t singleton::mutex;

singleton*singleton::initance()

4 餓漢實現

為什麼我不講「執行緒安全的餓漢實現」?因為餓漢實現本來就是執行緒安全的,不用加鎖。為啥?自己想!

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

classsingleton

private:

staticsingleton* p;

public:

staticsingleton* initance();

};

singleton* singleton::p =newsingleton;

singleton* singleton::initance()

是不是特別簡單呢?

以空間換時間,你說簡單不簡單?

面試的時候,執行緒安全的單例模式怎麼寫?肯定怎麼簡單怎麼寫呀!餓漢模式反而最懶[正經臉]! 

1 單例模式

乙個類只能有乙個例項。比如印表機這種東西。trick在於 變數,構造方法都必須為private,所以其他類new它的構造方法是不行的,直接呼叫變數也不行。只能呼叫getinstance 方法 其他被public修飾的方法。getinstance 方法記得用public修飾。原理 public cla...

1 單例模式

某個物件只需要乙個例項的情況,比方說gamemanager,resourcemanagerusing system namespace 單例模式 定義公有方法提供乙個全域性訪問點,同時你也可以定義公有屬性來提供全域性訪問點 public static singleton getinstance 構造...

單例模式1

1 餓漢式 author version 0.1 單例模式 餓漢式 建立時進行例項化 1 私有化構造方法 2 建立私有例項 static 3 建立公共類方法 static 方法輸出單例 public class singleton5 公共方法 public static singleton5 get...