单例设计模式是什么?什么是 Singleton 单例设计模式?Python 单例(单件)设计模式示例代码
什么是 Singleton 单例设计模式?
单例模式是一种创建型设计模式,它确保一个类只有一个实例,并提供一个全局访问点来访问该实例。

主要思想:
单例模式确保某个类只有一个实例,并提供了一个访问该实例的全局访问点。它常用于需要全局共享访问点的场景,例如日志记录器、数据库连接池、配置文件管理等。
主要角色:
- Singleton(单例类): 定义了一个静态方法来返回自身唯一的实例,并且该实例是静态成员变量。

工作流程:
- 将类的构造函数设为私有,以防止从外部直接实例化对象。
- 在类的内部创建一个静态私有成员变量来保存实例。
- 提供一个公共的静态方法来获取这个唯一的实例,如果实例不存在则创建,如果已存在则直接返回。
当使用单例模式时,有以下优点和缺点:
优点:
-
全局唯一实例: 单例模式确保一个类只有一个实例,提供了全局唯一的访问点,方便对实例的管理和控制。
-
节省系统资源: 由于单例模式只创建一个实例,可以节省系统资源和内存空间,特别是在频繁创建对象时有助于提高性能。
-
避免全局变量污染: 将状态保存在单例实例中可以避免全局变量的过度使用,减少了命名空间的污染。
-
提供了一个单一访问点: 可以通过单例对象来控制资源的访问和并发情况,使得资源的使用更加可控。
缺点:
-
全局状态: 单例模式引入全局状态,可能会增加系统的耦合度和复杂性,不利于单元测试和维护。
-
隐藏依赖关系: 单例模式隐藏了对象的创建方式和依赖关系,使得程序变得不透明,不利于追踪代码流程和理解程序逻辑。
-
滥用可能带来问题: 如果滥用单例模式,在某些情况下会导致性能问题、内存泄漏等,因此在使用时需要慎重考虑。
-
违反单一职责原则: 有时候单例类可能会承担过多的职责,违反了单一职责原则,导致类的职责不清晰。
-
线程安全问题: 在多线程环境下,单例模式需要考虑线程安全问题,可能需要额外的处理来保证线程安全性。
综上所述,单例模式在合适的情况下能提供全局唯一的访问点,节省资源和提高效率。但在不适合的场景下使用单例模式可能会引入一些问题,需要谨慎评估其利弊。
Python 实现单例设计模式示例代码(一):
class Singleton:_instance = Nonedef __new__(cls):if cls._instance is None:cls._instance = super().__new__(cls)return cls._instance# 使用示例
obj1 = Singleton()
obj2 = Singleton()print(obj1 is obj2) # 输出:True,表明obj1和obj2是同一个实例
这个示例展示了一个简单的单例模式实现。在这个例子中,Singleton 类中的 _instance 变量用来存储实例,在创建实例时,先检查是否已经存在实例,如果不存在则创建,存在则直接返回已有的实例。
单例模式的实现方式还有多种变种,例如基于装饰器、基于元类等。在实际开发中,要根据具体情况选择最适合的实现方式。
Python 实现单例设计模式示例代码(二):
当需要管理全局状态或资源时,比如在一个游戏中管理玩家信息,可以使用单例模式来确保只有一个玩家管理器实例:
class PlayerManager:_instance = Nonedef __new__(cls):if cls._instance is None:cls._instance = super().__new__(cls)# 初始化玩家列表等资源cls._instance.players = []return cls._instancedef add_player(self, player_name):self.players.append(player_name)print(f"Added player: {player_name}")def remove_player(self, player_name):if player_name in self.players:self.players.remove(player_name)print(f"Removed player: {player_name}")else:print(f"Player {player_name} not found")def get_players(self):return self.players# 使用示例
player_manager1 = PlayerManager()
player_manager1.add_player("Alice")player_manager2 = PlayerManager()
player_manager2.add_player("Bob")print(player_manager1.get_players()) # 输出:['Alice', 'Bob']
print(player_manager1 is player_manager2) # 输出:True
在这个示例中,PlayerManager 类用于管理玩家信息,它确保只有一个实例存在。无论创建多少次 PlayerManager 对象,都会得到同一个实例。这样,在不同的地方调用 PlayerManager 实例时,都能够操作同一份玩家列表信息。
使用单例设计模式时,需要注意哪些地方?
-
线程安全性: 如果应用涉及多线程,并且多个线程同时访问单例类,需要考虑线程安全问题。可以通过加锁或使用线程安全的方式来保证单例在多线程环境下的安全性。
-
延迟实例化: 如果实例化过程较为复杂,且不一定会用到单例,可以考虑延迟实例化,即在需要使用时再创建单例对象,以节省资源。
-
全局状态: 单例模式会引入全局状态,可能会增加系统的耦合性和复杂性。要谨慎考虑单例的使用场景,避免滥用。
-
测试难度: 单例模式可能会增加代码的测试难度,因为它引入了全局状态,可能需要额外的设置和清理来进行单元测试。
-
对外封装性: 为了保证单例的唯一性,通常需要将构造函数设为私有,这样外部无法直接创建对象,但也会限制了继承和扩展。
-
内存泄漏风险: 单例模式长期持有对象实例,如果没有及时释放资源,可能会导致内存泄漏问题,特别是在长时间运行的应用中。
-
多例模式误用: 有时候因为场景的误解,可能会误用单例模式,而需要多个实例。在这种情况下,应该避免使用单例模式,而是考虑其他模式或方式。
综上所述,虽然单例模式提供了一个方便的全局访问点,但在使用时需要权衡好利弊,避免滥用并考虑到单例可能引入的问题。
本文就到这里了,感谢您的阅读 。别忘了点赞、收藏~ Thanks♪(・ω・)ノ 🍇
相关文章:
单例设计模式是什么?什么是 Singleton 单例设计模式?Python 单例(单件)设计模式示例代码
什么是 Singleton 单例设计模式? 单例模式是一种创建型设计模式,它确保一个类只有一个实例,并提供一个全局访问点来访问该实例。 主要思想: 单例模式确保某个类只有一个实例,并提供了一个访问该实例的全局访问点。它…...
Redis跳跃表
前言 跳跃表(skiplist)是一种有序数据结构,它通过在每一个节点中维持多个指向其他节点的指针,从而达到快速访问节点的目的。 跳跃表支持平均O(logN),最坏O(N),复杂度的节点查找,还可以通过顺序性来批量处理节点…...
C++基础从0到1入门编程(二)
系统学习C 方便自己日后复习,错误的地方希望积极指正 往期文章:C基础从0到1入门编程(一) 参考视频: 1.黑马程序员匠心之作|C教程从0到1入门编程,学习编程不再难 2.系统化学习C 1 函数指针和回调函数 如果把函数的地址…...
Uniapp扫码预览连接地址与手机不在同一网段
在开发Uniapp应用时,这里有一个扫码预览的功能,电脑与手机都是在一网络下,之前点开后预览地址一直是169.254.3.x的地址,通过WINR键输入cmd运行,然后ipconfig查看所有网络连接。发现有一个虚拟网络连接的地址是169.251.…...
万界星空科技SMT行业生产管理MES系统解决方案
一、SMT行业特点: SMT(Surface Mounted Technology)作为电子组装行业里首先的技术和工艺,选择合适的MES解决方案来保障SMT生产的成功至关重要。 电子行业涉及的范围非常广,包含了汽车、电脑、电视、手机等产品上&…...
vue3 uniapp h5 安卓和iOS开发适配踩坑记录
font-size适配屏幕大小及iOS和安卓状态栏及安全距离的处理 App.vue <script setup lang"ts"> import { onLaunch, onShow, onHide } from "dcloudio/uni-app"; import ./main.scss onLaunch(() > {console.log("App Launch");var wid…...
inf和nan
在某些编程语法中inf表示无穷大,nan表示不是一个数(not a number) nan表示这个数不确定,而无穷大表示这个数任意大 1/0inf 这里把0当做一个无限接近0,但是非0的数 5-inf-inf 一个数减去无穷大会等于负无穷大 而inf-infnan 因为两个无穷大相减有很多可能,可能等于一个常数,也可能…...
十. Linux关机重启命令与Vim编辑的使用
关机重启命令 shutdown命令 其他关机命令 其他重启命令 系统运行级别 系统默认运行级别与查询 退出登录命令logout 文本编辑器Vim Vim简介 没有菜单,只有命令Vim工作模式 Vim常用命令 插入命令 定位命令 删除命令 复制和剪切命令 替换和取消命令 搜索和搜索替换命令 保存和退出…...
Spring-IOC-@Value和@PropertySource用法
1、Book.java PropertySource(value"classpath:配置文件地址") 替代 <context:property-placeholder location"配置文件地址"/> Value("${book.bid}") Value("${book.bname}") Value("${book.price}") <bean id&…...
如何理解Python中一切皆对象?
Python 一、示例代码二、Python中的魔法方法 一、示例代码 有理数类 import mathclass rational:def __init__(self,p,q):self.p pself.q qdef __str__(self):return "{} / {}".format(self.p,self.q)def simplify(self):gcd math.gcd(self.p,self.q)return rat…...
【如何学习Python自动化测试】—— 鼠标键盘操作
5 、 鼠标键盘操作 在浏览器中,通常会用到鼠标来进行操作,比如右键菜单中选择一个操作,在 selenium 中提供了下列鼠标相关操作。 ActionChains 类提供了以下方法: 点击鼠标:click()右击鼠标:context…...
随笔-事儿就这么个事儿
好久没写了,小A要催更,还答应让我写一下他的经历,这还有啥说的,开整。 1、升级 前段时间登录公司的办公系统处理一个事务申请,发现有个粗体标红的通知,是关于今年的晋升名单公示。进去看了一眼࿰…...
django理解03 数据库引入
配置 settings.py DATABASES {"default": {"ENGINE": "django.db.backends.mysql",NAME:307_django_db,USER: root,PASSWORD: 123456,HOST: 127.0.0.1,PORT: 3306,} }先创建指定名称的数据库databases create database self_django_db DEFAUL…...
Jtti:windows中apache怎么实现负载均衡
Jtti:windows中apache怎么实现负载均衡 在Windows环境下,你可以使用Apache HTTP Server搭建负载均衡集群。Apache提供了一个模块叫做mod_proxy,它可以用来实现反向代理和负载均衡。以下是一个简单的步骤来配置Apache负载均衡: 步骤…...
2311rust,到43版本更新
1.38.0 流水编译 要编译仓库,编译器不需要完全构建依赖项.相反,只需要它们的"元数据"(即类型,依赖关系,导出列表). 在编译过程的早期生成此元数据.从Rust1.38.0开始,Cargo利用这一点,在准备好元数据后立即自动开始构建依赖的仓库. 检查错误使用mem::{uninitialize…...
前端埋点上报的几种方式
现代Web应用程序中,埋点上报是一种重要的数据收集和分析手段。本文将介绍前端埋点上报的几种常见方式,并详细阐述如何在项目中运用这些方式进行数据上报,以帮助开发者更好地进行数据收集和分析。 上报方式 在前端中,常见的埋点上…...
外部 prometheus监控k8s集群资源
prometheus监控k8s集群资源 一,通过CADvisior 监控pod的资源状态1.1 授权外边用户可以访问prometheus接口。1.2 获取token保存1.3 配置prometheus.yml 启动并查看状态1.4 Grafana 导入仪表盘 二,通过kube-state-metrics 监控k8s资源状态2.1 部署 kube-st…...
centos安装神通数据库
1、安装 wget工具 yum install -y wget2、安装rar解压工具 wget --no-check-certificate http://www.rarlab.com/rar/rarlinux-x64-5.3.0.tar.gz tar zxvf rarlinux-x64-5.3.0.tar.gz && cd rar/ && make install3、下载oscar神通数据库(linux 64…...
汇编-PUSHFD和POPFD标志寄存器值压栈和出栈
PUSHFD指令将32位EFLAGS寄存器内容压入堆栈, 而POPFD指令则将栈顶单元内容弹出到EFLAGS寄存器 格式:...
基于SSM的进销存管理系统设计与实现
末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:采用JSP技术开发 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目&#x…...
多云管理“拦路虎”:深入解析网络互联、身份同步与成本可视化的技术复杂度
一、引言:多云环境的技术复杂性本质 企业采用多云策略已从技术选型升维至生存刚需。当业务系统分散部署在多个云平台时,基础设施的技术债呈现指数级积累。网络连接、身份认证、成本管理这三大核心挑战相互嵌套:跨云网络构建数据…...
React第五十七节 Router中RouterProvider使用详解及注意事项
前言 在 React Router v6.4 中,RouterProvider 是一个核心组件,用于提供基于数据路由(data routers)的新型路由方案。 它替代了传统的 <BrowserRouter>,支持更强大的数据加载和操作功能(如 loader 和…...
边缘计算医疗风险自查APP开发方案
核心目标:在便携设备(智能手表/家用检测仪)部署轻量化疾病预测模型,实现低延迟、隐私安全的实时健康风险评估。 一、技术架构设计 #mermaid-svg-iuNaeeLK2YoFKfao {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg…...
【位运算】消失的两个数字(hard)
消失的两个数字(hard) 题⽬描述:解法(位运算):Java 算法代码:更简便代码 题⽬链接:⾯试题 17.19. 消失的两个数字 题⽬描述: 给定⼀个数组,包含从 1 到 N 所有…...
【网络安全产品大调研系列】2. 体验漏洞扫描
前言 2023 年漏洞扫描服务市场规模预计为 3.06(十亿美元)。漏洞扫描服务市场行业预计将从 2024 年的 3.48(十亿美元)增长到 2032 年的 9.54(十亿美元)。预测期内漏洞扫描服务市场 CAGR(增长率&…...
最新SpringBoot+SpringCloud+Nacos微服务框架分享
文章目录 前言一、服务规划二、架构核心1.cloud的pom2.gateway的异常handler3.gateway的filter4、admin的pom5、admin的登录核心 三、code-helper分享总结 前言 最近有个活蛮赶的,根据Excel列的需求预估的工时直接打骨折,不要问我为什么,主要…...
2021-03-15 iview一些问题
1.iview 在使用tree组件时,发现没有set类的方法,只有get,那么要改变tree值,只能遍历treeData,递归修改treeData的checked,发现无法更改,原因在于check模式下,子元素的勾选状态跟父节…...
04-初识css
一、css样式引入 1.1.内部样式 <div style"width: 100px;"></div>1.2.外部样式 1.2.1.外部样式1 <style>.aa {width: 100px;} </style> <div class"aa"></div>1.2.2.外部样式2 <!-- rel内表面引入的是style样…...
自然语言处理——Transformer
自然语言处理——Transformer 自注意力机制多头注意力机制Transformer 虽然循环神经网络可以对具有序列特性的数据非常有效,它能挖掘数据中的时序信息以及语义信息,但是它有一个很大的缺陷——很难并行化。 我们可以考虑用CNN来替代RNN,但是…...
(转)什么是DockerCompose?它有什么作用?
一、什么是DockerCompose? DockerCompose可以基于Compose文件帮我们快速的部署分布式应用,而无需手动一个个创建和运行容器。 Compose文件是一个文本文件,通过指令定义集群中的每个容器如何运行。 DockerCompose就是把DockerFile转换成指令去运行。 …...
