單例模式的意圖與作用:
意圖:保證一個類僅有一個實例,並提供一個訪問它的全局訪問點。
作用:主要解決一個全局使用的類頻繁地創建與銷毀。
注意:在使用單例模式時構造函數是私有的。
優點:
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: 和上面代碼一樣
