懒汉式
单例模式是一种设计模式,其目的是保证程序中某个类只能存在一个实例,通常日志系统和程序中的管理类(比如用于管理回调函数的handle_manager等)会以单例模式实现,显然程序不希望这些数据结构存在多个。
c++单例模式有很多种写法,但c++11之后的单例模式,拒绝花里胡哨,直接上代码:
#include <iostream>
class singleton{
public:
static singleton* getInstance(){
static singleton p;
return &p;
}
private:
singleton(){};
~singleton(){};
singleton(const singleton& another) = delete;
singleton& operator=(const singleton& another) = delete;
};
int main(){
singleton* p1 = singleton::getInstance();
singleton* p2 = singleton::getInstance();
std::cout << "p1:" << p1 << " p2:" << p2 << std::endl;
return 0;
}
运行结果如下:
上面的写法是线程安全的,在需要时才第一次被初始化,被成为懒汉式,这种写法主要是利用了c++11局部静态变量的特性,多个局部静态变量同时初始化时,只有一个能进入初始化过程,其余被阻塞直到初始化完成,由于局部静态变量不会被销毁,多次访问访问的是同一个变量。
需要注意的是,上面的写法getInstance()返回值必须是指针,否则返回值会被另一个变量接收通过赋值运算符接收,而赋值运算符已经被我们显式地删除,因此编译时将报错,如下图。
饿汉式
下面是饿汉单例模式写法:
class singleton{
public:
static singleton* getInstance(){
return &p;
}
private:
singleton(){};
~singleton(){};
static singleton p;
singleton(const singleton& another) = delete;
singleton& operator=(const singleton& another) = delete;
};
singleton singleton::p;
int main(){
singleton* p1 = singleton::getInstance();
singleton* p2 = singleton::getInstance();
std::cout << "p1:" << p1 << " p2:" << p2 << std::endl;
return 0;
}
运行结果如下:
饿汉式利用了类外初始化,同样是线程安全的。