单例模式2.docx_第1页
单例模式2.docx_第2页
单例模式2.docx_第3页
单例模式2.docx_第4页
单例模式2.docx_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

=1=1. 最优实现class CSingletonpublic:static CSingleton& GetInstance()static CSingleton theSingleton;return theSingleton;/* more (non-static) functions here */private:CSingleton() / 必须定义, 且为private.CSingleton(const CSingleton&); / 不实现.CSingleton& operator=(const CSingleton&); / 不实现.CSingleton() / 可声明为public, 但这里声明为private没有错, 可被调用.;2. 其它实现class CSingleton:public:static CSingleton* GetInstance()if (!m_pInstance)m_pInstance = new CSingleton;return m_pInstance;/* more (non-static) functions here */private:CSingleton() / 必须定义, 且为private.static CSingleton* m_pInstance;class CGarbo / 它的唯一工作就是在析构函数中删除CSingleton的实例.public:CGarbo()if (CSingleton:m_pInstance)delete CSingleton:m_pInstance;static CGarbo m_garbo; / 定义一个静态成员, 在程序结束时, 系统会调用它的析构函数.;CSingleton* CSingleton:m_pInstance = NULL; / 这句必须有.=2=C+中的单例模式单例模式很有用,使用单例模式,保证一个类仅有一个实例,并提供一个访问它的全局访问点,该实例被所有程序模块共享。但是在程序的开发过程中我们总是遇到一些问题,而这些问题主要集中在单例类的消毁过程中,普通使用的单例模式的类如下:class Singleton:/ 其它成员public:static Singleton * GetInstance()if (m_pInstance = NULL)m_pInstance = new Singleton();return m_pInstance;private:Singleton();static Singleton * m_pInstance;可是这个类在什么时候调用它的析构函数呢,我们怎么消毁它。提供一个公用的destroy函数来进行它的消毁吗,这很不美观。最后我就在网上找到了如果下的代码处理了这个问题:class Singleton:/ 其它成员public:static Singleton * GetInstance().private:Singleton();static Singleton * m_pInstance;class CGarbo / 它的唯一工作就是在析构函数中删除Singleton的实例public:CGarbo()if (Singleton:m_pInstance)delete Singleton:m_pInstance;static CGarbo Garbo; / 定义一个静态成员,在程序结束时,系统会调用它的析构函数这是非常好的方法,静态成员对象 Garbo 在析构时会自动的消毁单例,我们不用再担心这个问题了。但是添加一个类的静态对象,总是让人不太满意,所以有人用如下方法来重现实现单例和解决它相应的问题,代码如下:class Singleton:/ 其它成员public:static Singleton &GetInstance()static Singleton instance;return instance;private:Singleton();使用局部静态变量,非常强大的方法,完全实现了单例的特性,而且代码量更少,也不用担心单例消毁的问题。在后期的项目中我全使用了这种方法,可是在项目的开发过程中还是出现了问题,当如下方法使用单例时问题来了,Singleton singletion = Singleto:GetInstance();这么做就产生了一个类拷贝的问题,这就为背了单例的特性。产生这个问题的原因在于,编译器会为类生成一个默认的构造函数,来支持类的拷贝。最后没有办法,我们要禁止类拷贝和类赋值,禁止程序员用这种方式来使用单例,当时领导的意思是GetInstance()函数返回一个指针而不是返回一个引用,函数代码改为如下:static Singleton *GetInstance()static Singleton instance;return &instance;可我总是感觉不好,为什么不让编译器不这么干呢。这时我才想起可以显式的声明类拷贝的构造函数,和重载操作符,新的单例类如下:class Singleton:/ 其它成员public:static Singleton &GetInstance()static Singleton instance;return instance;private:Singleton();Singleton(const Singleton&);Singleton & operate = (const Singleton&);关于Singleton(const Singleton&);和Singleton & operate = (const Singleton&);函数,我们要声明成私用的,并且只声明不实现。这样子后如果用上面的方式来使用单例时,不管是在友元类中还是其它的,编译器都是报错。不知道这样的单例类是否还会有问题,但在程序中这样子使用已经基本没有问题了。=3=单例模式的C+实现Singleton Constructorton1 var = 20ton2 var = 150 当我们要让一个类产生同一个对象对客户端服务的时候,比如管理数据库连接,管理文件IO等,这时我们就要使用到单例模式。下面是该模式的C+实现(注泽说明)#include using namespace std;/单例类的C+实现class Singletonprivate:Singleton();/注意:构造方法私有virtual Singleton();static Singleton* instance;/惟一实例int var;/成员变量(用于测试)public:static Singleton* GetInstance();/工厂方法(用来获得实例)int getVar();/获得var的值void setVar(int);/设置var的值;/构造方法实现Singleton:Singleton()this-var = 20;coutSingleton Constructorvar;void Singleton:setVar(int var)this-var = var;/mainint main(int argc, char* argv)Singleton *ton1 = Singleton:GetInstance();Singleton *ton2 = Singleton:GetInstance();coutt

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论