单例模式在项目是最常用的设计模式之一,一个稍大点的项目,往往有很多类使用了单例模式,所以掌握单例模式至关重要。但是看过太多项目中使用的单例模式并不规范,只是简单的将默认构造函数私有化然后提供一个静态成员函数获取对象。其存在两大问题:
1、不私有化拷贝构造函数和赋值运算符,更有甚者,自己还在代码中使用了拷贝构造函数或者赋值运算符,单例变多例,如 A a = A::instance();。不理解 单例 为何意。
2、不考虑创建对象时线程安全问题。如:
Test *Test::getInstance()
{
static Test *instance = nullptr;
if(NULL == instance)
{
instance = new Test();
}
return instance;
}
为了解决上述两个问题,在写单例模式时,需要将拷贝构造函数和赋值运算符一并私有化,并保证创建对象时线程安全。若是项目中很多单例类,每个都去私有化这些函数,比较麻烦,且往往忘记了拷贝构造函数和赋值运算符怎么书写,现提供两个使类单例化的宏:
#pragma once
#define SINGLETON(T) \
public: \
static T &instance() \
{ \
static T sInstance; \
return sInstance; \
} \
private: \
T(const T&); \
T& operator=(const T&); \
private:
#define SINGLETON_PRO(T) \
public: \
static T &instance() \
{ \
static T sInstance; \
return sInstance; \
} \
private: \
T(){}; \
T(const T&); \
T& operator=(const T&); \
private:
在需要单例化的类中只需要引入该宏即可:
class Protocol
{
SINGLETON_PRO(Protocol)
public:
...
};
c++11之后,静态局部变量初始化是保证线程安全的,解决了上述两个问题。