QT之单例模式

单例模式的意图与作用:

  意图:保证一个类仅有一个实例,并提供一个访问它的全局访问点。

  作用:主要解决一个全局使用的类频繁地创建与销毁。

  注意:在使用单例模式时构造函数是私有的。

优点:

  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:
    和上面代码一样            

猜你喜欢

转载自www.cnblogs.com/caozewen/p/12514809.html
今日推荐