Qt单例模式的实现(4种⽅法)
最简单的写法:
1static MyClass* MyClass::Instance()
2 {
3static MyClass inst;
4return &inst;
5 }
过去很长⼀段时间⼀直都这么写,简单粗暴有效。但是直接声明静态对象会使编译出的可执⾏⽂件增⼤,也有可能出现其他的⼀些问题,所以利⽤了Qt⾃带的智能指针QScopedPointer和线程锁QMutex,改成了需要时才动态初始化的模式:
1static MyClass* MyClass::Instance()
2 {
3static QMutex mutex;
4static QScopedPointer<MyClass> inst;
5if (Q_UNLIKELY(!inst)) {
6 mutex.lock();
7if (!inst) {
8 set(new MyClass);
9 }
10 mutex.unlock();
11 }
12return inst.data();
13 }
既保证了线程安全⼜防⽌了内存泄漏,效率也没降低太多,简直完美。
可惜每次都要重复这么⼏⾏实在⿇烦,于是写了⼀个模板类:
1 template <class T>
2class Singleton
3 {
4public:
5static T* Instance()
6 {
7static QMutex mutex;
8static QScopedPointer<T> inst;
9if (Q_UNLIKELY(!inst)) {
10 mutex.lock();
11if (!inst) {
12 set(new T);
13 }
14 mutex.unlock();
15 }
16return inst.data();
17 }
18 };
使⽤的时候直接这样——
MyClass* inst = Singleton<MyClass>::Instance();
除了⽤模板类,还可以利⽤c++中强⼤的宏:
1#define DECLARE_SINGLETON(Class) \
2 Q_DISABLE_COPY(Class) \
3public: \
4static Class* Instance() \
5 { \
6static QMutex mutex; \
7static QScopedPointer<Class> inst; \
8if (Q_UNLIKELY(!inst)) { \
9 mutex.lock(); \
10if (!inst) set(new Class); \
11 mutex.unlock(); \
12 } \
13return inst.data(); \
14 }
然后声明的时候,填加⼀⾏这个宏:
1class MyClass
2 {
3 DECLARE_SINGLETON(MyClass); // 声明单例模式
单例模式的几种实现方式4//...
5 }
好评好评。
当然,为了要保证真的是单例模式,还要把构造函数限制为private,不然以后什么时候忘记了这码事,在外⾯⼜new了⼀下就不好了。
另外Qt本⾝⾃带了⼀个宏Q_GLOBAL_STATIC,也有类似单例模式的效果,QThreadPool::globalInstance()函数的实现就是利⽤了这个宏。不过它的主要⽤处是声明全局变量,和Singleton还是有差别的。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论