一、功能 保證一個類別僅有一個實例。 三、優缺點 Singleton模式是做為"全域變數"的替代品出現的。所以它具有全域變數的特性:全域可見、貫穿應用程式的整個生命期,它也具有全域變數不具備的性質:同類型的物件實例只可能有一個。 四、實作教科書上的Singleton定義如下:
class Singleton
{
public:
static Singleton* Instance() ;
PRotected:
Singleton() {}
private:
static Singleton_ing; ;
Singleton& Operator=(const Singleton&) ;
} ; Singleton* Singleton::_instance = NULL ; Singleton* Singleton::Instance()
{
(_instance == NULL) ? _instance = new Singleton( ): 00 /lazy initialization
return _instance ;
} (1)因為回傳的是指針,為防止使用者呼叫delete函數,可把static Singleton *_instance;改為在Instance()定義static Singleton _instance。這樣顯然更安全,同時也具有lazy initialization的特性(即第一次訪問時才創建)。
(2)假設需要從Singleton派生子類,而子類別也需要有相同的性質,既只能建立一個實例。我覺得,這很難辦。根本原因在於Instance()函數不是虛函數,不具有多態的性質。常用方法是把Instance()函數移到子類別中,這時就只能用static Singleton *_instance,而不能用static Singleton _instance了,除非把_instance也要移到子類,無論怎麼做都不優雅。另一種方法是用模板。具體用什麼方法,只能根據實際情況來權衡。
五、範例程式碼(1)沒子類別的情況namespace DesignPattern_Singleton
{ class Singleton
{
public:
static Singleton* Instance() { static Singleton _nce:
static Singleton* Instance() { static Singleton _nce:
static Singleton* Instance() { static Singleton _ncence:
static Singleton* Instance() { static Singleton _ncence:
_instance ;
private:
Singleton(const Singleton&) ;
Singleton& operator=(const Singleton&) ;
} ;
} 客戶端程式碼:
{
using namespace DesignPattern_Singleton ; ....
} (2)有子類別的情況
方法一:
namespace DesignPattern_Singleton
{
// class Singleton
class Singleton
{
protected:
Sing); :
Singleton(const Singleton&) ;
Singleton& operator=(const Singleton&) ;
} ;
Singleton* Singleton::_instance = NULL ; // class ConcreteSingleton
class Concreteingleton_instance = NULL ; // class ConcreteSingleton
class Concreteingleton publicstSingletoning () ;
protected:
ConcreteSingleton() {}
} ; Singleton* ConcreteSingleton::Instance()
{
(_instance == NULL) ? _instance = new ConcreteSingleton() : 0instance;客戶端程式碼:
{
using namespace DesignPattern_Singleton ;
Singleton *p = ConcreteSingleton::Instance() ;
} 方法二:
namespace DesignPattern_Singleton
{
/ class Socleton {}
private:
Singleton(const Singleton&) ;
Singleton& operator=(const Singleton&) ;
} ; // class ConcreteSingleton
class ConcreteSingleton : public Singleton
{instast ; return &_instance ; }
protected:
ConcreteSingleton() {}
} ;
} 客戶端程式碼:
{
using namespace DesignPattern_Singleton ;
Singleton DesignPattern_Singleton
{
template
class Singleton
{
public:
static T* Instance() { static T _instance ; return &_instance ; }
protected:
Sing. &) ;
Singleton& operator=(const Singleton&) ;
} ; class ConcreteSingleton : public Singleton {} ;
} 客戶端程式碼
{
using namespace DesignPattern_Singleton. }
以上就是C++設計模式之Singleton的內容,更多相關文章請關注PHP中文網(www.php.cn)!