单例模式——懒汉模式(C++)
生活随笔
收集整理的這篇文章主要介紹了
单例模式——懒汉模式(C++)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
//懶漢模式
//優點: 第一次使用實例對象時,創建對象
//缺點: 復雜#include <iostream>
#include <mutex>
#include <thread>
using namespace std;class Singleton
{
public:static Singleton* GetInstance() //獲取實例{if (_spInstance == nullptr) //雙檢查(Double-Check),保證效率和線程安全//第二個以后的線程不用檢查鎖,提高效率{_smtx.lock(); //(多線程)第一個線程進來,并行的第二個線程進不來if (_spInstance == nullptr){_spInstance = new Singleton;}_smtx.unlock();}return _spInstance;}// 實現一個內嵌垃圾回收類 class CGarbo{public:~CGarbo() {if (_spInstance){delete _spInstance;}}};private:Singleton(){cout << "Singleton()" << endl;}~Singleton() //調CGarbo類的析構{cout << "~Singleton()" << endl;}//防拷貝Singleton(const Singleton&) = delete;Singleton& operator=(const Singleton&) = delete;static Singleton* _spInstance; //單例對象指針static mutex _smtx; //互斥鎖static CGarbo _scg;
};Singleton* Singleton::_spInstance = nullptr;
mutex Singleton::_smtx;Singleton::CGarbo Singleton::_scg;//測試多線程
void func()
{//Singleton::GetInstance(); //若不加鎖,會丟掉第一個線程的返回值cout << Singleton::GetInstance() << endl; //測試一下
}int main()
{//多線程,兩個線程并行去調func函數(用來測試)thread t1(func); thread t2(func);//線程等待t1.join();t2.join();cout << Singleton::GetInstance() << endl;cout << Singleton::GetInstance() << endl;return 0;
}
?
總結
以上是生活随笔為你收集整理的单例模式——懒汉模式(C++)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 实现memmove
- 下一篇: Linux——进程控制(总结)