手机
当前位置:查字典教程网 >编程开发 >C语言 >C++ 中的单例模式(普通,2B,文艺)
C++ 中的单例模式(普通,2B,文艺)
摘要:一、普通Singleton复制代码代码如下:#includeusingnamespacestd;classSingleton{public:...

一、普通Singleton

复制代码 代码如下:

#include<iostream>

using namespace std;

class Singleton

{

public:

static Singleton* getInstance();

private:

static Singleton* instance;

Singleton()

{

cout<<"constructorn";

// do something

};

~Singleton()

{

cout<<"destructorn";

//do something

}

};

Singleton* Singleton::instance = NULL;

Singleton* Singleton::getInstance()

{

if(instance == NULL)

instance = new Singleton();

return instance;

}

int main()

{

cout<<"begin mainn";

Singleton* instance = Singleton::getInstance();

cout<<"end mainn";

}

但是这样构造函数不会自动调用,需要用户这个类的用户手动delete instance. 这样是不太好的

这是懒汉式的,在多线程的情况下需要同步。也可以写成饿汉式的,但是c++里面写成饿汉式的不太好,如果有多个单例类,而他们是相互引用的,那么饿汉式就有可能出问题。因为在C++中,这几个单例类的静态成员的初始化顺序是不确定的。

二、2B的Singleton

复制代码 代码如下:

#include<iostream>

using namespace std;

class Singleton

{

public:

static Singleton* getInstance();

private:

static Singleton* instance;

Singleton()

{

cout<<"constructorn";

// do something

};

~Singleton()

{

cout<<"destructorn";

//do something

}

class Garbo

{

public:

~Garbo()

{

cout<<"Garbo destructorn";

if(Singleton::instance != NULL)

delete Singleton::instance;

}

};

static Garbo garbo;

};

Singleton* Singleton::instance = NULL;

Singleton::Garbo Singleton::garbo;

Singleton* Singleton::getInstance()

{

if(instance == NULL)

instance = new Singleton();

return instance;

}

int main()

{

cout<<"begin mainn";

Singleton* instance = Singleton::getInstance();

cout<<"end mainn";

}

用了一个内部类, Garbo。 由于main结束后,会自动释放 garbo, 而garbo就会调用instance的destructor.

三、文艺Singleton

复制代码 代码如下:

#include<iostream>

using namespace std;

class Singleton

{

public:

static Singleton* getInstance();

private:

static Singleton instance;

Singleton()

{

cout<<"constructorn";

// do something

};

~Singleton()

{

cout<<"destructorn";

//do something

}

};

Singleton Singleton::instance;

Singleton* Singleton::getInstance()

{

return &instance;

}

int main()

{

cout<<"begin mainn";

Singleton* instance = Singleton::getInstance();

cout<<"end mainn";

}

instance在main开始前就已经构造好了,在main结束后会自动释放。

但是这样的话,只能是饿汉式的singleton。如果在构造函数中需要申请大量资源,这些资源就一直存在在整个运行阶段。而不管这些资源什么时候需要,什么时候不许要。

四、改进的文艺Singleton

复制代码 代码如下:

#include<iostream>

using namespace std;

class Singleton

{

public:

static Singleton* getInstance();

private:

Singleton()

{

cout<<"constructorn";

// do something

};

~Singleton()

{

cout<<"destructorn";

//do something

}

};

Singleton* Singleton::getInstance()

{

static Singleton instance;

return &instance;

}

int main()

{

cout<<"begin mainn";

Singleton* instance = Singleton::getInstance();

cout<<"end mainn";

}

这样,就可以在需要的时候再构造singleton, 也就是懒汉式的。

【C++ 中的单例模式(普通,2B,文艺)】相关文章:

C++中对象的常引用总结

C字符串与C++中string的区别详解

C++中返回指向函数的指针示例

C 语言基础教程(我的C之旅开始了)[六]

C++类中的常量介绍

C++中sprintf()函数的使用详解

C++中的常对象与常对象成员详解

C++中的异或运算符^的使用方法

浅析C/C++中的可变参数与默认参数

C++类中的常数据成员与静态数据成员之间的区别

精品推荐
分类导航