关于C++单例模式的终极总结
2014-11-19 11:50
260 查看
不废话 贴代码!
#include<iostream>
#include<mutex>
class Singleton{
private:
static Singleton* instance;
static std::mutex mutex;
Singleton(){}
Singleton(const Singleton& s);
Singleton& operator=(const Singleton& s);
public:
static Singleton* getInstance(){//静态函数 因为不能通过对象调用!
if (instance==NULL){
mutex.lock();
}
if (instance == NULL){
static Singleton s;
instance = &s;
mutex.unlock();
}
return instance;
}
};
Singleton* Singleton::instance = NULL;
std::mutex Singleton::mutex ;
int main(){
Singleton* S1 = Singleton::getInstance();
Singleton* S2 = Singleton::getInstance();
if(S1==S2){
std::cout << "只有一个实例!" << std::endl;
}
system("pause");
}
解决了动态释放的问题,并且加了双锁,解决了多线程的问题!不用动态创建对象,用static,保证了单一性也保证了不被销毁的问题!
#include<iostream>
#include<mutex>
class Singleton{
private:
static Singleton* instance;
static std::mutex mutex;
Singleton(){}
Singleton(const Singleton& s);
Singleton& operator=(const Singleton& s);
public:
static Singleton* getInstance(){//静态函数 因为不能通过对象调用!
if (instance==NULL){
mutex.lock();
}
if (instance == NULL){
static Singleton s;
instance = &s;
mutex.unlock();
}
return instance;
}
};
Singleton* Singleton::instance = NULL;
std::mutex Singleton::mutex ;
int main(){
Singleton* S1 = Singleton::getInstance();
Singleton* S2 = Singleton::getInstance();
if(S1==S2){
std::cout << "只有一个实例!" << std::endl;
}
system("pause");
}
解决了动态释放的问题,并且加了双锁,解决了多线程的问题!不用动态创建对象,用static,保证了单一性也保证了不被销毁的问题!
相关文章推荐
- C++经典对话上关于模式的两篇好文章
- JAVA与C++::关于JNI中文字符串操作问题总结
- 【C++】Chapter25:模式总结(上)
- 关于C++ const 的全面总结
- 关于C++的一些总结
- 关于Gof设计模式的精辟总结
- 总结C++中三种关于”new”的使用方法
- C/C++中关于递归的实现细节的总结
- 关于C++ const 的全面总结
- 关于C++ const 的全面总结
- 关于C++单件模式释放对象
- C++单体模式的几个总结
- 关于C++ const 的全面总结
- JAVA与C++::关于JNI中文字符串操作问题总结
- 关于C++ const 的全面总结
- 关于c/c++ static 总结
- 关于C++ const 的全面总结
- c++中关于return的用法总结
- 【C++】Chapter25:模式总结(下)
- 关于工厂模式的一些总结