C++学习Day04之单例模式

目录

  • 一、程序及输出
    • [1.1 饿汉式实例](#1.1 饿汉式实例)
    • [1.2 饿汉式单例](#1.2 饿汉式单例)
    • [1.3 懒汉式单例](#1.3 懒汉式单例)
    • [1.4 线程安全的懒汉式单例](#1.4 线程安全的懒汉式单例)
  • 二、分析与总结

一、程序及输出

1.1 饿汉式实例

c 复制代码
#include<iostream>
using namespace std;
#include <string>
class Printer
{
public:
	static Printer * getInstance()//获取实例方法
	{
		return printer;
	}

	void printText(string text)
	{
		m_Count++;
		cout << text << endl;
	}

	int m_Count;

private:
	Printer() //单例构造函数
	{ 
		m_Count = 0;
		cout << "打印机构造调用" << endl; 
	};

	Printer(const Printer & p){};//拷贝构造函数

	static Printer * printer;//单例实体
	
};

Printer * Printer::printer = new Printer();//类外初始化

void test01()
{
	Printer * p1 = Printer::getInstance();
	p1->printText("入职证明");
	p1->printText("离职证明");
	p1->printText("加薪申请");
	p1->printText("旅游申请");

	cout << "打印机使用次数: " << p1->m_Count << endl;

	Printer * p2 = Printer::getInstance();
	p2->printText("调休申请");

	cout << "打印机使用次数: " << p1->m_Count << endl;

}

int main(){
  cout << "mian函数调用" << endl;    //单例模式编译阶段就分配内存,所以单例模式的构造函数会先打印。
	test01();
	system("pause");
	return EXIT_SUCCESS;
}

输出:

可以看到,单例的创建是在全局作用域中进行初始化,编译阶段就分配内存,所以单例模式的构造函数会先打印

1.2 饿汉式单例

饿汉式单例模式

在程序启动时即创建单例实例。这样可以确保在多线程环境下也不会出现多个实例被创建的情况。

实现方式是将构造函数私有化,然后在类的内部定义一个静态成员变量来保存单例实例,并提供一个静态成员函数用于获取该实例。

c 复制代码
class Singleton {
public:
    static Singleton * getInstance() {
        return instance;
    }

private:
    Singleton() {}

    static Singleton * instance;
};

Singleton * Singleton::instance = new Singleton();

跟我们最开始的实例框架结构一致

1.3 懒汉式单例

懒汉式单例模式

在需要时才创建单例实例。这种方式可能需要考虑多线程环境下的线程安全性。

实现方式是将构造函数私有化,然后在类的内部定义一个静态成员变量指针,并在静态成员函数中进行实例化。

c 复制代码
class Singleton {
public:
    static Singleton * getInstance() {
        if (instance == nullptr) {
            instance = new Singleton();
        }
        return instance;
    }

private:
    Singleton() {}

    static Singleton * instance;
};

Singleton * Singleton::instance = nullptr;

1.4 线程安全的懒汉式单例

线程安全的懒汉式单例模式

在懒汉式单例模式的基础上,通过加锁等手段来确保在多线程环境下也只有一个实例被创建。

可以使用互斥锁(mutex)或双重检查锁定(double-checked locking)等方式来实现线程安全的单例模式。

c 复制代码
class Singleton {
public:
    static Singleton * getInstance() {
        if (instance == nullptr) {
            std::lock_guard<std::mutex> lock(mutex);
            if (instance == nullptr) {
                instance = new Singleton();
            }
        }
        return instance;
    }

private:
    Singleton() {}

    static Singleton * instance;
    static std::mutex mutex;
};

Singleton * Singleton::instance = nullptr;
std::mutex Singleton::mutex;

二、分析与总结

单例设计模式是一种创建型设计模式,用于确保类只有一个实例,并提供全局访问点以访问该实例

分为饿汉式懒汉式

在具体使用过程中注意线程安全、实例化过程等细节

相关推荐
小柯博客7 分钟前
STM32MP2安全启动技术深度解析
c语言·c++·stm32·嵌入式硬件·安全·开源·github
cpp_250115 分钟前
P1832 A+B Problem(再升级)
数据结构·c++·算法·动态规划·题解·洛谷·背包dp
结衣结衣.42 分钟前
手把手教你实现文档搜索引擎
linux·c++·搜索引擎·开源·c++11
t***5441 小时前
如何在 Dev-C++ 中切换编译器
java·开发语言·c++
jiayong231 小时前
第 38 课:任务列表里高亮当前正在查看详情的任务
开发语言·前端·javascript·vue.js·学习
大肥羊学校懒羊羊1 小时前
完数与盈数的计算题解
数据结构·c++·算法
澈2071 小时前
构造函数与析构函数完全指南
开发语言·c++
W23035765731 小时前
C++ 高并发线程池实战(二):动态缓存线程池 + 调用者运行拒绝策略完整版实现
开发语言·c++·缓存
t***5441 小时前
如何在 Dev-C++ 中使用 Clang 编译器
开发语言·c++
lwf0061641 小时前
逻辑回归学习笔记-数学直接解回归方程
笔记·学习·逻辑回归