C++单体类 || 单例模式 的实现
来源:互联网 发布:阿里云主机绑定域名 编辑:程序博客网 时间:2024/06/05 06:05
单件模式是设计模式中最简单的模式了。
定义: 确保一个类只有一个实例,并提供一个全局的访问点。
- 把一个类设计成自己管理的一个单独实例,同时避免其他类再自行生成实例(所以构造函数用protect或privite)
- 也提供全局的访问点。public函数
一、
普通Singleton
#include<iostream>
using namespace std;
class Singleton
{
public:
static Singleton* getInstance();
private:
static Singleton* instance;
Singleton()
{
cout<<"constructor\n";
// do something
};
~Singleton()
{
cout<<"destructor\n";
//do something
}
};
Singleton* Singleton::instance = NULL;
Singleton* Singleton::getInstance()
{
if(instance == NULL)
instance = new Singleton();
return instance;
}
int main()
{
cout<<"begin main\n";
Singleton* instance = Singleton::getInstance();
cout<<"end main\n";
}
但是这样构造函数不会自动调用,需要用户这个类的用户手动delete instance. 这样是不太好的
这是懒汉式的,在多线程的情况下需要同步。也可以写成饿汉式的,但是c++里面写成饿汉式的不太好,如果有多个单例类,而他们是相互引用的,那么饿汉式就有可能出问题。因为在C++中,这几个单例类的静态成员的初始化顺序是不确定的。
二、
2B的Singleton
#include<iostream>
using namespace std;
class Singleton
{
public:
static Singleton* getInstance();
private:
static Singleton* instance;
Singleton()
{
cout<<"constructor\n";
// do something
};
~Singleton()
{
cout<<"destructor\n";
//do something
}
class Garbo
{
public:
~Garbo()
{
cout<<"Garbo destructor\n";
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 main\n";
Singleton* instance = Singleton::getInstance();
cout<<"end main\n";
}
用了一个内部类, Garbo。 由于main结束后,会自动释放 garbo, 而garbo就会调用instance的destructor.
三、
文艺Singleton
#include<iostream>
using namespace std;
class Singleton
{
public:
static Singleton* getInstance();
private:
static Singleton instance;
Singleton()
{
cout<<"constructor\n";
// do something
};
~Singleton()
{
cout<<"destructor\n";
//do something
}
};
Singleton Singleton::instance;
Singleton* Singleton::getInstance()
{
return &instance;
}
int main()
{
cout<<"begin main\n";
Singleton* instance = Singleton::getInstance();
cout<<"end main\n";
}
instance在main开始前就已经构造好了,在main结束后会自动释放。
但是这样的话,只能是饿汉式的singleton。如果在构造函数中需要申请大量资源,这些资源就一直存在在整个运行阶段。而不管这些资源什么时候需要,什么时候不许要。
#include<iostream>
using namespace std;
class Singleton
{
public:
static Singleton* getInstance();
private:
Singleton()
{
cout<<"constructor\n";
// do something
};
~Singleton()
{
cout<<"destructor\n";
//do something
}
};
Singleton* Singleton::getInstance()
{
static Singleton instance;
return &instance;
}
int main()
{
cout<<"begin main\n";
Singleton* instance = Singleton::getInstance();
cout<<"end main\n";
}
这样,就可以在需要的时候再构造singleton, 也就是懒汉式的
- C++单体类 || 单例模式 的实现
- 单例/单体模式(Singleton)
- 单例/单体模式(Singleton)
- 单例/单体模式(Singleton)
- 单例/单体模式(Singleton)
- 单例/单体模式(Singleton)
- 单例/单体模式(Singleton)
- javascript 单例/单体模式(Singleton)
- c++中单体模式的实现
- Unity3d C# 脚本单体模式的实现
- js设计模式——单例/单体模式
- JavaScript 设计模式之----单体(单例)模式
- JavaScript 设计模式之----单体(单例)模式
- 【Objective-C】单例模式的实现
- Objective-C 单例模式的实现
- c++--Singleton单例模式的实现
- C#.net Singleton 单体模式
- C++里的单体类实现
- linux下c语言可变参函数
- libvirt中使用 virtio 总线类型
- 关于VirtualBox
- Geant4认识1
- MediaInfo源代码分析 5:JPEG解析代码分析
- C++单体类 || 单例模式 的实现
- 使用标准模板库 (STL)之一
- Java基础 之强引用(Strong Reference)、软引用(Soft Reference)、弱引用(WeakReference)、虚引用(Phantom Reference)
- CentOS 中增加新的工作区
- 建立简单的服务器端程序
- 曾经的“战友”!
- 关于路由的一点理解,还有编址
- OpenCV绘图之字体和文字
- 棋盘覆盖问题的算法实现