2.单例模式

一、定义

确保一个类仅有一个唯一的实例,并且提供一个全局的访问点。

二、要解决的问题

  • 独生子女
    无论new了多少个对象,始终只存在一个实例
  • 应用场景
    对临界资源(例如日志、打印机)的访问

三、解决步骤

  1. 将构造函数声明成私有类型
  2. 声明一个类的静态实例
  3. 提供一个获得实例的方法

四、代码实现

4.1 实现方法1

下面这种方式存在以下问题

  • 只提供了getInstance方法获取对象,没有提供释放函数
  • 析构函数不会被运行
  • 多线程调用getInstance时将不是线程安全的
cpp 复制代码
class Singleton
{
private:
	static Singleton* singleton;  //实例对象为私有

	Singleton()  //构造方法为私有
	{
		std::cout << "Singleton" << std::endl;
	}
	
	~Singleton()
	{
		std::cout << "~Singleton" << std::endl;
	}

public:
	static Singleton& getInstance()
	{
		if (!singleton)
		{
			singleton = new Singleton();
		}

		return *singleton;
	}

	void printAddress()
	{
		printf("%p\n", this);
	}
};

Singleton* Singleton::singleton = nullptr;

4.2 实现方法2

改进点

  • 禁止单例模式的拷贝和赋值
  • 采用局部静态变量的方式返回,线程安全(c++11及以后)
  • 没有采用new关键字在堆空间中申请内存,空间被自动管理
  • 析构函数被自动执行
cpp 复制代码
class Singleton
{
private:
	Singleton()  //构造方法为私有
	{
		std::cout << "Singleton" << std::endl;
	}
	~Singleton()
	{
		std::cout << "~Singleton" << std::endl;
	}

	//禁止拷贝和赋值
	Singleton(const Singleton& obj) = delete;
	Singleton& operator=(const Singleton& obj) = delete;


public:
	static Singleton& getIntance()
	{
		static Singleton instance;

		return instance;
	}

	void printAddress()
	{
		printf("%p\n", this);
	}
};

int main()
{
	Singleton::getIntance().printAddress();
	Singleton::getIntance().printAddress();
}
相关推荐
佛祖让我来巡山4 小时前
设计模式深度解析:策略模式、责任链模式与模板模式
设计模式·责任链模式·策略模式·模版模式
__万波__5 小时前
二十三种设计模式(三)--抽象工厂模式
java·设计模式·抽象工厂模式
转转技术团队5 小时前
VDOM 编年史
前端·设计模式·前端框架
明洞日记8 小时前
【设计模式手册014】解释器模式 - 语言解释的优雅实现
java·设计模式·解释器模式
ZHE|张恒8 小时前
设计模式(十六)迭代器模式 — 统一访问集合元素的方式,不暴露内部结构
设计模式·迭代器模式
未秃头的程序猿11 小时前
🚀 设计模式在复杂支付系统中的应用:策略+工厂+模板方法模式实战
后端·设计模式
雨中飘荡的记忆12 小时前
深入理解设计模式之单例模式
java·设计模式
8***293113 小时前
能懂!基于Springboot的用户增删查改(三层设计模式)
spring boot·后端·设计模式
在未来等你1 天前
AI Agent设计模式 Day 19:Feedback-Loop模式:反馈循环与自我优化
设计模式·llm·react·ai agent·plan-and-execute
兵bing1 天前
设计模式-访问者模式
设计模式·访问者模式