C++设计模式-单例模式(双重锁定)
                                                            生活随笔
收集整理的這篇文章主要介紹了
                                C++设计模式-单例模式(双重锁定)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.                        
                                目錄
?
?
基本概念
代碼與實例
?
基本概念
單例模式以前都出過一個了,再次只粗略講下!
單例模式:保證一個類僅有一個實例,并提供一個訪問它的全局訪問點
其中UML圖如下(來自于大話設計模式)
?
?
代碼與實例
下面是最基礎的單例模式!
運行截圖如下:
代碼如下:
Head.h
#ifndef HEAD_H #define HEAD_H#include <iostream> #include <string> #include <assert.h> using namespace std;class SingleTon{public:static SingleTon *getInstance(){if(m_instance == nullptr){m_instance = new SingleTon;return m_instance;}return m_instance;}~SingleTon(){cout << "~SingleTon() called!" << endl;}void toDoSometing(){if(m_instance == nullptr){assert(!"呵呵噠");}cout << this <<" 雅喵蝶 是一只大蝴蝶" << endl;}private:SingleTon(){}SingleTon(SingleTon &singleTon){}static SingleTon *m_instance; };SingleTon *SingleTon::m_instance = nullptr;#endifmain.cpp
#include "Head.h"int main(int *argc, int *argv[]){SingleTon *singleTon = nullptr;singleTon = SingleTon::getInstance();singleTon->toDoSometing();SingleTon *hehe = nullptr;hehe = SingleTon::getInstance();hehe->toDoSometing();delete singleTon;getchar();return 0; }?
這個是個很好的設計模式,但是在多線程中就要操作下了!
雙重鎖定!!!!
運行截圖還是這樣的,但加了1個鎖,這個lock鎖可以讓其他線程都阻塞掉。
這個就是多線程單例,但是每次調用getInstance時候都需要lock,會影響性能。
下面這種方式為雙重鎖定,先判斷實例是否存在,不存在在加鎖處理
這里有個疑問:
外面以及判斷了instance實例是否存在,為什么還要在lock里面做一次判斷?這不是脫褲子打屁嗎?
原因:當instance為null并且同時有2個線程調用getInstance方法時候,他們都會通過第一重的instance == null 的判斷。然后由于lock機制,就只有一個線程能進入,另外一個線程等待,如果沒有第二個判斷,那么是不是就多new了空間,而且不能釋放,是不是就變成了垃圾代碼。
代碼如下:
#ifndef HEAD_H #define HEAD_H#include <iostream> #include <string> #include <mutex> #include <assert.h> using namespace std;mutex mt;class SingleTon{public:static SingleTon *getInstance(){if(m_instance == nullptr){mt.lock();if(m_instance == nullptr){m_instance = new SingleTon;mt.unlock();return m_instance;}}mt.unlock();return m_instance;}~SingleTon(){cout << "~SingleTon() called!" << endl;}void toDoSometing(){if(m_instance == nullptr){assert(!"呵呵噠");}cout << this <<" 雅喵蝶 是一只大蝴蝶" << endl;}private:SingleTon(){}SingleTon(SingleTon &singleTon){}static SingleTon *m_instance; };SingleTon *SingleTon::m_instance = nullptr;#endif?
總結
以上是生活随笔為你收集整理的C++设计模式-单例模式(双重锁定)的全部內容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: Qt文档阅读笔记-Qt4 Lower-L
 - 下一篇: Java笔记-多线程中同步加锁相关