"懒汉模式",注意多线程时可能多次构造,这里使用两次判断加锁解决。
cpp
#include <iostream>
#include <mutex>
std::mutex g_mutex;
class testA {
public:
static testA* GetInstance() {
if (singleton == nullptr)
{
std::unique_lock<std::mutex> lock(g_mutex); //RAII自动上锁解锁
if (singleton == nullptr)
{
singleton = new testA();
}
}
return singleton;
}
private:
testA() {
std::cout << "进行构造函数使用" << std::endl;
};
static testA* singleton;
};
//初始化成员变量
testA* testA::singleton = nullptr;
int main()
{
testA* a = testA::GetInstance();
testA* b = testA::GetInstance();
return 0;
}
饿汉模式,类声明即初始化,无线程安全问题
cpp
#include <iostream>
class testA {
public:
static testA* GetInstance() {
return singleton;
}
private:
testA() {
std::cout << "进行构造函数使用" << std::endl;
};
static testA* singleton;
};
//初始化成员变量
testA* testA::singleton = new testA();
int main()
{
testA* a = testA::GetInstance();
testA* b = testA::GetInstance();
return 0;
}
实现原理为在私有成员函数中声明类的构造函数,这样默认构造函数就不会有了。然后将其设置为static静态成员变量,可使用类::函数名称方式直接调用。饿汉模式为类声明好之后直接初始化,懒汉模式为用的时候判断是否为空指针,如果为空指针则声明。