当前位置: 首页 > news >正文

设计模式 : 单例模式笔记

在这里插入图片描述

文章目录

  • 一.单例模式
  • 二.单例模式的两种实现方式
    • 饿汉模式
    • 懒汉模式

一.单例模式

  • 一个类只能创建一个对象,这样的类的设计模式就称为单例模式,该模式保证系统中该类只能有一个实例(并且父子进程共享),一个很典型的单例类就是C++STL的内存池
  • C++单例模式的基本设计思路:
    • 私有化构造函数,删除默认的拷贝构造函数赋值运算符重载防止对象被直接创建和拷贝
    • 单例对象的内存资源可以交给操作系统来释放,也可以自定义析构函数来完成特殊操作

二.单例模式的两种实现方式

饿汉模式

  • 饿汉单例类在程序进入主函数之前就创建出唯一的实例
//饿汉单例模式
class HungerSingleton
{
public://定义一个可以访问单例对象的静态接口static HungerSingleton* Getinstance(){return &singleObj;}
private://构造函数私有化,防止对象被直接创建HungerSingleton() { cout << "单例对象创建" << endl; }//删除拷贝接口,防止对象被拷贝HungerSingleton(const HungerSingleton& single) = delete;HungerSingleton& operator=(const HungerSingleton& single) = delete;private://定义静态区的HungerSingleton成员static HungerSingleton singleObj;//也可以定义成指针,初始化时在堆上创建//static HungerSingleton* singleObj;
};
//初始化类的静态成员
HungerSingleton HungerSingleton::singleObj;
//初始化时在堆上创建
//HungerSingleton * HungerSingleton::singleObj = new HungerSingleton;
  • HungerSingleton静态成员变量自身类型的对象(或指针),类的静态成员变量在进入主函数之前就完成初始化,由于构造函数被私有化,因此在程序运行过程中无法再创建该类的对象
  • 饿汉单例模式的优势:
    • 由于子进程只能在主函数中被创建,因此饿汉单例类不存在线程安全问题,无需与其他线程的类竞争系统资源,在多线程高并发环境下能够较为高效地执行任务
  • 饿汉单例模式的劣势:
    • 如果一个程序中有多种饿汉单例类,我们无法控制它们的初始化顺序
    • 饿汉单例类会拖慢程序的启动速度,而且即便用不到该类也会创建一个实例,可能造成内存浪费

懒汉模式

  • 懒汉单例类在程序进入主函数之后由后续代码决定是否创建实例
//懒汉单例模式
class LazySingleton
{
public://定义一个可以访问单例对象的静态接口static LazySingleton* Getinstance(){//若singleObj为空指针则创建单例对象if (singleObj == nullptr){singleObj = new LazySingleton;}return singleObj;}
private://构造函数私有化,防止对象被创建LazySingleton() { cout << "单例对象创建" << endl; }//删除拷贝接口,防止对象被拷贝LazySingleton(const LazySingleton& single) = delete;LazySingleton& operator=(const LazySingleton& single) = delete;private://定义成静态成员指针,初始化时在堆上创建static LazySingleton* singleObj;
};
//初始化时设置成空指针
LazySingleton * LazySingleton::singleObj = nullptr;
  • LazySingleton类在第一次调用Getinstance()成员接口时才会创建实例
  • 懒汉单例模式的优势:
    • 可以控制多种懒汉单例类对象的初始化顺序,并且需要用到的时候才创建,避免了内存浪费
  • 懒汉单例模式的劣势:
    • 在多线程环境中存在线程安全问题,需要加锁
      在这里插入图片描述
http://www.lryc.cn/news/131511.html

相关文章:

  • 深度优先搜索算法
  • k8s ----POD控制器详解
  • ReactNative进阶(三十四):ipa Archive 阶段报错error: Multiple commands produce问题修复及思考
  • MySQL索引ES索引
  • webSocket 聊天室 node.js 版
  • iptables防火墙(SNAT与DNAT)
  • 第 359 场 LeetCode 周赛题解
  • 【开源项目】Stream-Query的入门使用和原理分析
  • 微信小程序picker组件的简单使用 单选
  • python、numpy、pytorch中的浅拷贝和深拷贝
  • EasyRecovery14数据恢复软件支持各类存储设备的数据恢复
  • 玩机搞机----面具模块的组成 制作模块
  • 注册中心/配置管理 —— SpringCloud Consul
  • Next.js 13 你需要了解的 8 件事
  • 计数排序(Count Sort)算法详解
  • Linux驱动开发(Day3)
  • 使用Vscode调试shell脚本
  • OpenAI Function calling
  • 【C语言】字符分类函数、字符转换函数、内存函数
  • Deep Learning With Pytorch - 最基本的感知机、贯序模型/分类、拟合
  • 测试工具coverage的高阶使用
  • 安卓监听端口接收消息
  • 「Node」下载安装配置node.js
  • NOIP2014普及组,提高组 比例简化 飞扬的小鸟 答案
  • 【Java】使用Apache POI识别PPT中的图片和文字,以及对应的大小、坐标、颜色、字体等
  • 根据源码,模拟实现 RabbitMQ - 实现消息持久化,统一硬盘操作(3)
  • 找到所有数组中消失的数(C语言详解)
  • 计算机毕设项目之基于django+mysql的疫情实时监控大屏系统(前后全分离)
  • Unity UI内存泄漏优化
  • 学习笔记:Opencv实现图像特征提取算法SIFT