单例模式(懒汉模式,饿汉模式)

单例的饿汉模式:在主函数未调用之前该单例就已经存在了,所以不存在线程安全的问题。

class Singleton
{
private: Singleton(){}
public:
	static Singleton  s1;
	static Singleton* GetInstance()
	{
		return &s1;
	}
	Singleton(const Singleton&) = delete;
	Singleton& operator= (const Singleton &) = delete;
};
int main()
{
	Singleton* p = Singleton::GetInstance();
	return 0;
}//为调用主函数前就已经创建了该对象,单例模式多用于日志模块或者数据库模块,饿汉式是线程安全的。

 线程安全的懒汉单例模式:懒汉单例模式是在调用函数的时候生成的,为了防止同一个线程调用需要加上互斥锁。同时减小锁的粒度,采用锁+双重判断的方式

std::mutex mx;
class Singleton
{
private: Singleton() {}
public:
	static Singleton*  volatile s1;
	static Singleton* GetInstance()
	{
		if (s1 == nullptr)
		{
			std::lock_guard<std::mutex>lock(mx);   //锁+双重判断  线程安全的懒汉式单例模式最安全的
			if(s1 == nullptr)
			s1 = new Singleton();
		}
		return s1;
	}
	Singleton(const Singleton&) = delete;
	Singleton& operator= (const Singleton&) = delete;
};
Singleton* volatile  Singleton::s1 = nullptr;   //CPU为了提高效率会进行该内容的拷贝给每个线程,加上这个之后将不会再进行拷贝而使每个线程可以察觉到

 极为简洁的懒汉单例模式:在局部的静态变量中默认存在着互斥锁,本身不存在线程安全问题,所以在局部变量的情况下不需要维护线程安全问题。

//非常精简的懒汉单例模式,静态成员局部变量本身就是线程安全的问题。
class Singleton
{
private: Singleton() {}
public:
	
	static Singleton* GetInstance()
	{
		static Singleton  s1;
		return &s1;
	}
	Singleton(const Singleton&) = delete;
	Singleton& operator= (const Singleton&) = delete;
};

 

  • 12
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值