单例设计模式共享数据

单例设计模式共享数据

一、懒汉模式下多线程安全问题

class mySingle
{
public:
	static mySingle* getInstance()
	{
		if (myInstance == nullptr)
		{
			std::lock_guard<std::mutex>myUniqueLock(myMutex);
			if (myInstance == nullptr)
			{
				myInstance = new mySingle();
				static mySingle::garbage mygarbage;
				std::cout << "creat obj" << std::endl;
			}
		}
			return myInstance;
	}
	class garbage
	{
	public:
		~garbage()
		{
			if (mySingle::myInstance)
			{
				delete mySingle::myInstance;
				myInstance = nullptr;
				std::cout << "delete" << std::endl;
			}
		}
	};

private:
	mySingle() {};
	std::mutex myMutex;
	static mySingle* myInstance;
	
};
mySingle* mySingle::myInstance = nullptr;
std::mutex mySingle::myMutex;

二、std::call_once()

功能:保证函数a()只会被调用一次 ;具备互斥量这种能力,比互斥量消耗的资源更少;需要结合一个标记使用std::once_flag在函数被调用后,标志位就会标记函数已经是被调用状态。

class mySingle
{
public:
	static mySingle* getInstance()
	{
			std::call_once(myFlag, creatInstance);
			return myInstance;
	}
	static void creatInstance()
	{
		std::this_thread::sleep_for(std::chrono::milliseconds(2000));
		myInstance = new mySingle();
		static mySingle::garbage mygarbage;
		std::cout << "creat obj" << std::endl;
	}
	class garbage
	{
	public:
		~garbage()
		{
			if (mySingle::myInstance)
			{
				delete mySingle::myInstance;
				myInstance = nullptr;
				std::cout << "delete" << std::endl;
			}
		}
	};

private:
	static std::once_flag myFlag;
	static std::mutex myMutex;
	static mySingle* myInstance;
	
};
mySingle* mySingle::myInstance = nullptr;
std::once_flag mySingle::myFlag;
std::mutex mySingle::myMutex;

推荐第一种写法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值