我們見到經常有人用 static 局部對象的方式實現了類似單例模式,最近發現一篇文章明確寫明 編譯器在處理 ?static局部變量的時候 并不是線程安全的 !!!
[http://blogs.msdn.com/b/oldnewthing/archive/2004/03/08/85901.aspx ](http://blogs.msdn.com/b/oldnewthing/archive/2004/03/08/85901.aspx)? ??
于是實現了一個單例工廠 ?并且是線程安全的
~~~
#ifndef SINGLETONFACTORY_H
#define SINGLETONFACTORY_H
#include "windows.h"
#include <memory>
namespace Tools
{
template<class T>class SingletonFactory
{
public:
virtual ~SingletonFactory()
{
::DeleteCriticalSection(&__criticalSection);
}
std::auto_ptr<T>& GetInstance();
static SingletonFactory<T>* CreateSingletonFactory();
private:
SingletonFactory()
{
::InitializeCriticalSection(&__criticalSection);
}
std::auto_ptr<T> __singletonObj;
CRITICAL_SECTION __criticalSection;
};
//初始化創建 后續在多線程中使用
//還有另一種寫法是單獨的函數直接返回內部單例包裝靜態成員在 多線程情況下不安全
//SingletonFactory::CreateSingletonFactory().GetInstance();
template<class T> SingletonFactory<T>* SingletonFactory<T>::CreateSingletonFactory(){
static SingletonFactory<T> temObj;
return &temObj;
}
//工廠實例
template<class T> std::auto_ptr<T>& SingletonFactory<T>::GetInstance()
{
if(__singletonObj.get()==0)
{
::EnterCriticalSection(&__criticalSection);
if(__singletonObj.get()==0)
__singletonObj=std::auto_ptr<T>(new T);
::LeaveCriticalSection(&__criticalSection);
}
return __singletonObj;
}
}
#endif // SINGLETONFACTORY_H
~~~
測試代碼?
~~~
SingletonFactory<Data1>*singleton1=SingletonFactory<Data1>::CreateSingletonFactory();
singleton1->GetInstance()->x=100;
cout<<singleton1->GetInstance()->x<<endl;
singleton1->GetInstance()->y=200;
cout<<singleton1->GetInstance()->x<<endl;
cout<<singleton1->GetInstance()->y<<endl;
SingletonFactory<Data2>*singleton2=SingletonFactory<Data2>::CreateSingletonFactory();
singleton2->GetInstance()->x=100;
cout<<singleton2->GetInstance()->x<<endl;
singleton2->GetInstance()->y=200;
cout<<singleton2->GetInstance()->x<<endl;
cout<<singleton2->GetInstance()->y<<endl;
~~~
- 前言
- C++數據結構與算法------------二叉樹的2種創建
- 二叉樹的創建以及利用迭代實現中序、先序、后序遍歷、清空
- 數據結構-----哈夫曼樹的構造以及遍歷
- 二叉搜索樹的非遞歸創建和搜索
- 二叉搜索樹非遞歸方式刪除節點
- Lua中table內建排序與C/C++/Java/php/等內排序算法的排序效率比較
- 內嵌匯編與C/C++實現的冒泡排序,快速排序算法排序500W個數據對比
- 菜鳥學算法--簡單的交換和最大公約數算法入門篇
- 菜鳥學算法----改進后的歐幾里得算法
- C++實現一個線程安全的單例工廠
- 關于有序二維矩陣查找和字符串替換的兩道算法題
- 算法有序數組合并---在空間足夠的情況下,進行O(n)的合并 并且移動次數最小