计划模式 - 单例模式
一个类不管创建多少次对象,永远只能得到该范例一个对象的气力常用到的,比如日记模块,数据库模块
饿汉式单例模式:还没有获取实例对象,实例对象就已经产生了
懒汉式单例模式:唯一的实例对象,直到第一次获取它的时间,才产生
饿汉式单例模式 饿汉式单例模式一定是线程安全的
#include <iostream>
using namespace std;
class Singleton
{
public:
static Singleton* getInstance() //3.获取类的唯一实例对象的接口方法
{
return &instance;
}
private:
static Singleton instance;//2.定义一个唯一的类的实例对象
Singleton() //1.构造函数私有化
{
}
Singleton(const Singleton&) = delete;
Singleton& operator=(const Singleton&) = delete;
};
Singleton Singleton::instance;
int main()
{
Singleton* p1 = Singleton::getInstance();
Singleton* p2 = Singleton::getInstance();
Singleton* p3 = Singleton::getInstance();
cout << p1 << " " << p2 << " " << p3 << " " << endl;
return 0;
} 懒汉式单例模式 线程安全的懒汉式单例模式案例
#include <iostream>
#include <mutex>
using namespace std;
std::mutex mtx;
class Singleton
{
public:
//是不是可重入函数呢? 锁+双重判断
static Singleton* getInstance() //3.获取类的唯一实例对象的接口方法
{
//lock_guard<std::mutex> lck(mtx);//锁的力度太大了
if (instance == nullptr)
{
lock_guard<std::mutex> lck(mtx);
if (instance == nullptr)
{
//开辟内存,构造对象,给instance赋值
instance = new Singleton();
}
}
return instance;
}
private:
static Singleton *volatile instance;//2.定义一个唯一的类的实例对象
Singleton() //1.构造函数私有化
{
}
Singleton(const Singleton&) = delete;
Singleton& operator=(const Singleton&) = delete;
};
Singleton* volatile Singleton::instance = nullptr;
int main()
{
Singleton* p1 = Singleton::getInstance();
Singleton* p2 = Singleton::getInstance();
Singleton* p3 = Singleton::getInstance();
cout << p1 << " " << p2 << " " << p3 << " " << endl;
return 0;
} 更加简便的懒汉式单例模式
#include <iostream>
#include <mutex>
using namespace std;
std::mutex mtx;
class Singleton
{
public:
//是不是可重入函数呢? 锁+双重判断
static Singleton* getInstance() //3.获取类的唯一实例对象的接口方法
{
static Singleton instance;//2.定义一个唯一的类的实例对象
return &instance;
}
private:
Singleton() //1.构造函数私有化
{
}
Singleton(const Singleton&) = delete;
Singleton& operator=(const Singleton&) = delete;
};
int main()
{
Singleton* p1 = Singleton::getInstance();
Singleton* p2 = Singleton::getInstance();
Singleton* p3 = Singleton::getInstance();
cout << p1 << " " << p2 << " " << p3 << " " << endl;
return 0;
}
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]