单例模式的意图与作用:
意图:保证一个类仅有一个实例,并提供一个访问它的全局访问点。
作用:主要解决一个全局使用的类频繁地创建与销毁。
注意:在使用单例模式时构造函数是私有的。
优点:
1、在内存里只有一个实例,减少了内存的开销,尤其是频繁的创建和销毁实例。
2、避免对资源的多重占用(比如写文件操作)。
缺点:没有接口,不能继承,与单一职责原则冲突,一个类应该只关心内部逻辑,而不关心外面怎么样来实例化。
1 class SingleTon{
2 public:
3 static SingleTon &getInstance(void)
4 {
5 //双重检测加锁
6 if(!instance){
7 QMutexLocker locker(&mutex);
8 if(!instance)
9 instance = new SingleTon;
10 }
11 return * instance;
12 }
13 private:
14 SingleTon()
15 SingleTon(const SingleTon & );
16 SingleTon & operator = (const SingleTon &);
17 QReadWriteLock internalMutex;
18 static QMutex mutex;
19 static QAtomicPointer<SingleTon> instance;
20 };
21
22 //初始化静态变量
23 QMutex SingleTon::mutex;
24 QAtomicPointer<SingleTon> SingleTon::instance = 0;
修改:
1 public:
2 static SingleTon &getInstance(void)
3 {
4 #ifdef Q_ATOMIC_POINTER_TEST_AND_SET_IS_ALWAYS_NATIVE
5 if(!QAtomicPointer::isTestAndSetNative())//运行时进行检测
6 qDebug() << "Error: don's support TestAndSetNative!!!!!!"
7 #endif
8 //双重检测加锁
9 /* ! testAndSetOrders操作保证在原子操作前和后的的内存访问
10 * 不会被重新排序。
11 */
12 if(instance.testAndSetOrdered(0,0)){ //第一次检测
13 QMutexLocker locker(&mutex) //加锁
14 instance.testAndSetOrdered(0, new SingleTon); //第二次检查
15 }
16 return * instance;
17 }
18 private:
19 和上面代码一样
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
· 全程使用 AI 从 0 到 1 写了个小工具
· 从文本到图像:SSE 如何助力 AI 内容实时呈现?(Typescript篇)
2020-06-22 Qt 对话框窗体关闭时,如何自动销毁窗体类对象、清空内存