单例模式的意图与作用:
意图:保证一个类仅有一个实例,并提供一个访问它的全局访问点。
作用:主要解决一个全局使用的类频繁地创建与销毁。
注意:在使用单例模式时构造函数是私有的。
优点:
1、在内存里只有一个实例,减少了内存的开销,尤其是频繁的创建和销毁实例。
2、避免对资源的多重占用(比如写文件操作)。
缺点:没有接口,不能继承,与单一职责原则冲突,一个类应该只关心内部逻辑,而不关心外面怎么样来实例化。
class SingleTon{ public: static SingleTon &getInstance(void) { //双重检测加锁 if(!instance){ QMutexLocker locker(&mutex); if(!instance) instance = new SingleTon; } return * instance; } private: SingleTon() SingleTon(const SingleTon & ); SingleTon & operator = (const SingleTon &); QReadWriteLock internalMutex; static QMutex mutex; static QAtomicPointer<SingleTon> instance; }; //初始化静态变量 QMutex SingleTon::mutex; QAtomicPointer<SingleTon> SingleTon::instance = 0;
修改:
public: static SingleTon &getInstance(void) { #ifdef Q_ATOMIC_POINTER_TEST_AND_SET_IS_ALWAYS_NATIVE if(!QAtomicPointer::isTestAndSetNative())//运行时进行检测 qDebug() << "Error: don‘s support TestAndSetNative!!!!!!" #endif //双重检测加锁 /* ! testAndSetOrders操作保证在原子操作前和后的的内存访问 * 不会被重新排序。 */ if(instance.testAndSetOrdered(0,0)){ //第一次检测 QMutexLocker locker(&mutex) //加锁 instance.testAndSetOrdered(0, new SingleTon); //第二次检查 } return * instance; } private: 和上面代码一样
原文:https://www.cnblogs.com/caozewen/p/12514809.html