单例模式(饿汉模式和懒汉模式实现)

单例模式

单例模式的概念

一个类智能创建一个对象,单例模式可以保证系统中该类只有一个实例,并提供一个访问他的全局访问点,该实例被所有程序模块共享

饿汉模式

不管用不用,程序启东时就创建一个唯一的实例对象

优点:简单
缺点:可能会导致进程启动慢,且如果有多个单例模式对象实例启动顺序不确定

#include <iostream>

using namespace std;

class Singleton
{
public:
	static Singleton* GetInstance()
	{
		return &m_instance;
	}
private:
	//构造函数私有
	Singleton()
	{

	}

	//C++98防拷贝
	Singleton(const Singleton&);
	Singleton& operator=(Singleton const&);

	//C++11防止拷贝
	Singleton(const Singleton&) = delete;
	Singleton& operator=(Singleton const&) = delete;

	static Singleton m_instance;
};

Singleton Singleton::m_instance;//在程序入口之前就完成单利对象的初始化

int main()
{

	system("pause");
	return 0;
}

懒汉模式

延迟加载

优点:第一次使用实例对象时,创建对象,进程启动无负载,多个单例实例启动顺序自由控制
缺点:复杂

#include <iostream>
#include <mutex>
#include <thread>

using namespace std;

class Singleton
{
public:
	static Singleton* GetInstance()
	{
		if (m_pInstance == nullptr)
		{
			m_mutex.lock();
			if (m_pInstance == nullptr)
			{
				m_pInstance = new Singleton();
			}
			m_mutex.unlock();
		}
		return m_pInstance;
	}

	//实现一个内嵌垃圾回收类
	class CGarbo
	{
	public:
		~CGarbo()
		{
			if (Singleton::m_pInstance)
			{
				delete Singleton::m_pInstance;
			}
		}
	public:
		//定义一个静态成员变量,程序结束时,系统会自动调用它的析构函数从而释放单例对象
		static CGarbo Garbo;
	};

private:
	//构造函数
	Singleton()
	{

	}

	//C++98防拷贝
	Singleton(const Singleton&);
	Singleton& operator=(Singleton const&);
	
	////C++11防止拷贝
	//Singleton(const Singleton&) = delete;
	//Singleton& operator=(Singleton const&) = delete;

	static Singleton* m_pInstance;//单例对象指针
	static mutex m_mutex;//互斥锁

};

Singleton* Singleton::m_pInstance = nullptr;
Singleton::CGarbo Garbo;
mutex Singleton::m_mutex;

void Func(int n)
{
	cout << Singleton::GetInstance() << endl;
}

int main()
{

	thread t1(Func, 10);
	thread t2(Func, 10);

	t1.join();
	t2.join();

	cout << Singleton::GetInstance() << endl;
	cout << Singleton::GetInstance() << endl;

	system("pause");
	return 0;
}

发布了117 篇原创文章 · 获赞 48 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/gp1330782530/article/details/105231972