c++11 改进设计模式 Singleton模式
关于学习 《深入应用c++11》的代码笔记:
c++11之前是这么实现的
template<typename T>
class Singleton{
public:
static T* Instance(){
if (m_pInstance == nullptr)
m_pInstance = new T();
return m_pInstance;
} template<typename T0>
static T* Instance(T0 arg0){
if (m_pInstance == nullptr)
m_pInstance = new T(arg0);
return m_pInstance;
} template<typename T0,typename T1>
static T* Instance(T0 arg0, T1 arg1){
if (m_pInstance == nullptr)
m_pInstance = new T(arg0, arg1);
return m_pInstance;
} template<typename T0, typename T1,typename T2>
static T* Instance(T0 arg0, T1 arg1,T2 arg2){
if (m_pInstance == nullptr)
m_pInstance = new T(arg0, arg1,arg2);
return m_pInstance;
} template<typename T0, typename T1, typename T2,typename T3>
static T* Instance(T0 arg0, T1 arg1, T2 arg2,T3 arg3){
if (m_pInstance == nullptr)
m_pInstance = new T(arg0, arg1, arg2,arg3);
return m_pInstance;
} template<typename T0, typename T1, typename T2, typename T3,typename T4>
static T* Instance(T0 arg0, T1 arg1, T2 arg2, T3 arg3,T4 arg4){
if (m_pInstance == nullptr)
m_pInstance = new T(arg0, arg1, arg2, arg3,arg4);
return m_pInstance;
} template<typename T0, typename T1, typename T2, typename T3, typename T4,typename T5>
static T* Instance(T0 arg0, T1 arg1, T2 arg2, T3 arg3, T4 arg4,T5 arg5){
if (m_pInstance == nullptr)
m_pInstance = new T(arg0, arg1, arg2, arg3, arg4,arg5);
return m_pInstance;
} static T* GetInstance()
{
if (m_pInstance == nullptr)
throw std::logic_error("the instance is not init,please init the instance first"); return m_pInstance;
} static void DestroyInstance(){
delete m_pInstance;
m_pInstance = nullptr;
} private:
Singleton(void);
virtual ~Singleton(void);
Singleton(const Singleton&);
Singleton& operator = (const Singleton); static T* m_pInstance;
}; template<class T> T* Singleton<T>::m_pInstance = nullptr; //============================================
struct A{
A(){}
}; struct B{
B(int x){}
}; struct C{
C(int x, double y){}
}; int _tmain(int argc, _TCHAR* argv[])
{
Singleton<A>::Instance();
Singleton<A>::Instance();
Singleton<B>::Instance(1);
Singleton<C>::Instance(1,3.14); Singleton<A>::DestroyInstance();
Singleton<B>::DestroyInstance();
Singleton<C>::DestroyInstance(); return 0;
}
c++11之后可以简略一点,使用了可变模板参数
template<typename T>
class Singleton{
public:
template <typename... Args>
static T* Instance(Args&&... args){
if (m_pInstance == nullptr)
m_pInstance = new T(std::forward<Args>(args)...);
return m_pInstance;
} static T* GetInstance(){
if (m_pInstance == nullptr)
throw std::logic_error("the instance is not init,please initialize the instance first");
return m_pInstance;
} static void DestroyInstance()
{
delete m_pInstance;
m_pInstance = nullptr;
} private:
Singleton(void);
virtual ~Singleton(void);
Singleton(const Singleton&);
Singleton& operator=(const Singleton&);
private:
static T* m_pInstance;
}; template<class T>T* Singleton<T>::m_pInstance = nullptr; #include <iostream>
#include <string> using namespace std; struct A{
A(const string&){ cout << "lvalue" << endl; }
A(string&&x){ cout << "rvalue" << endl; }
}; struct B{
B(const string&){ cout << "lvalue" << endl; }
B(string&& x){ cout << "rvalue" << endl; }
}; struct C{
C(int x, double y){}
void Fun(){ cout << "Test" << endl; }
}; int _tmain(int argc, _TCHAR* argv[])
{
string str = "bb";
Singleton<A>::Instance(str);
Singleton<B>::Instance(std::move(str));
Singleton<C>::Instance(1,3.14);
Singleton<C>::GetInstance()->Fun(); Singleton<A>::DestroyInstance();
Singleton<B>::DestroyInstance();
Singleton<C>::DestroyInstance(); return 0;
}
c++11 改进设计模式 Singleton模式的更多相关文章
- (原创)c++11改进我们的模式之改进访问者模式
本次讲c++11改进我们的模式之改进访问者模式 访问者模式是GOF23个设计模式中比较复杂的模式之一,但是它的功能也很强大,非常适合稳定的继承层次中对象的访问,可以在不修改被访问对象的情况下,动态添加 ...
- (原创)c++11改进我们的模式之改进命令模式
模式虽然精妙,却难完美,比如观察者模式中观察者生命周期的问题:比如访问者模式中循环依赖的问题等等:其它很多模式也存在这样那样的一些不足之处,如使用场景受限.实现复杂.不够简洁.不够通用等.但我觉得不足 ...
- (原创)c++11改进我们的模式之改进单例模式
我会写关于c++11的一个系列的文章,会讲到如何使用c++11改进我们的程序,本次讲如何改进我们的模式,会讲到如何改进单例模式.观察者模式.访问者模式.工厂模式.命令模式等模式.通过c++11的改进, ...
- (原创)c++11改进我们的模式之改进代理模式,实现通用的AOP框架
c++11 boost技术交流群:296561497,欢迎大家来交流技术. 本次要讲的时候如何改进代理模式,具体来说是动态代理模式,动态代理模式一般实现AOP框架,不懂AOP的童鞋看这里.我前面的博文 ...
- 1.设计模式 - Singleton模式(单件模式)
Singleton是一种创建型模式,指某个类采用Singleton模式,则在这个类被创建后,只可能产生一个实例供外部访问,并且提供一个全局的访问点,一般用于Activity的控制层全局对象和Singl ...
- (原创)c++11改进我们的模式之改进表驱动模式
所谓表驱动法(Table-Driven Approach),简单讲是指用查表的方法获取值.表驱动是将一些通过较为复杂逻辑语句来得到数据信息的方式,通过查询表的方式来实现,将数据信息存放在表里.对于消除 ...
- (原创)c++11改进我们的模式之改进观察者模式
和单例模式面临的是同样的问题,主题更新的接口难以统一,很难做出一个通用的观察者模式,还是用到可变模板参数解决这个问题,其次还用到了右值引用,避免多余的内存移动.c++11版本的观察者模式支持注册的观察 ...
- 转:Singleton模式
C++完美实现Singleton模式 转自:http://www.cppblog.com/dyj057/archive/2005/09/20/346.html boost库的Singleton的实现 ...
- Java设计模式(2)单态模式(Singleton模式)
定义:Singleton模式主要作用是保证在Java应用程序中,一个类Class只有一个实例存在. 在很多操作中,比如建立目录 数据库连接都需要这样的单线程操作. 还有,singleton能够被状态化 ...
随机推荐
- PyQt5系列教程(八)定时器QTimer的使用
软硬件环境 OS X EI Capitan Python 3.5.1 PyQt 5.5.1 前言 如果需要在程序中周期性地进行某项操作,比如检测某种设备的状态,就会用到定时器.本文就来看看PyQT5中 ...
- centos7.3安装zip,unzip
安装命令: yum install -y unzip zip
- angular 获取当前值
- 21OGNL与ValueStack(VS)-静态方法访问
转自:https://wenku.baidu.com/view/84fa86ae360cba1aa911da02.html 在LoginAction中增加如下方法: public static Str ...
- CSS镂空图片处理
来源:http://www.zhangxinxu.com/wordpress/?p=5267,分享收藏 使用镂空图片,通过CSS改变颜色,达到图片切换的效果,可以同过背景图,然后改变背景色,从而达到图 ...
- windows自带杀毒防火墙
windows自带杀毒防火墙 Windows Defender FireWall
- 可视化库-seaborn-布局风格设置(第五天)
1. sns.set_style() 进行风格设置, sns.set() 进行设置的重置, 五种风格 # 1.darkgrid# 2.whitegrid# 3.dark# 4.white# 5 tic ...
- int和Integer区别
Java是一个近乎纯洁的面向对象编程语言,但是为了编程的方便还是引入了基本数据类型,但是为了能够将这些基本数据类型当成对象操作,Java为每一个基本数据类型都引入了对应的包装类型(wrapper cl ...
- jquery实现背景图片动态适应
背景 在我的一个项目中用到了背景图片,发现其中有一个问题,当页面长度动态变化时,原来能占满全部内容背景的图片会变得不能占满全部背景.如下图的效果: 这是正常的,背景图片占满全屏 当页面内容变长出现了滚 ...
- Get与Post提交方式的区别
用 curl 测试 post 请求: curl -d "agentCode=RB&startDate=2017-07-01&endDate=2017-09-01& ...