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:
    和上面代碼一樣            

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM