详解python的单例模式

ops/2025/2/1 5:15:49/

单例模式是一种设计模式,它确保一个类只有一个实例,并提供一个全局访问点来获取这个实例。在Python中实现单例模式有多种方法,下面我将详细介绍几种常见的实现方式。

1. 使用模块

Python的模块天然就是单例的,因为模块在第一次导入时会被加载到内存中,之后的导入都是直接使用内存中的模块对象。因此,你可以通过模块来实现单例模式。

python"># singleton.py
class SingletonClass:def __init__(self):self.value = "Singleton Value"singleton_instance = SingletonClass()# main.py
from singleton import singleton_instanceprint(singleton_instance.value)  # 输出: Singleton Value

2. 使用装饰器

你可以使用装饰器来控制类的实例化过程,确保只有一个实例被创建。

python">def singleton(cls):instances = {}def get_instance(*args, **kwargs):if cls not in instances:instances[cls] = cls(*args, **kwargs)return instances[cls]return get_instance@singleton
class SingletonClass:def __init__(self):self.value = "Singleton Value"instance1 = SingletonClass()
instance2 = SingletonClass()print(instance1 is instance2)  # 输出: True

3. 使用类方法

你可以在类中定义一个类方法来控制实例的创建。

python">class SingletonClass:_instance = Nonedef __init__(self):self.value = "Singleton Value"@classmethoddef get_instance(cls):if cls._instance is None:cls._instance = cls()return cls._instanceinstance1 = SingletonClass.get_instance()
instance2 = SingletonClass.get_instance()print(instance1 is instance2)  # 输出: True

4. 使用元类

元类可以控制类的创建过程,因此可以通过元类来实现单例模式。

python">class SingletonMeta(type):_instances = {}def __call__(cls, *args, **kwargs):if cls not in cls._instances:cls._instances[cls] = super().__call__(*args, **kwargs)return cls._instances[cls]class SingletonClass(metaclass=SingletonMeta):def __init__(self):self.value = "Singleton Value"instance1 = SingletonClass()
instance2 = SingletonClass()print(instance1 is instance2)  # 输出: True

5. 使用__new__方法

你可以重写类的__new__方法来控制实例的创建。

python">class SingletonClass:_instance = Nonedef __new__(cls, *args, **kwargs):if cls._instance is None:cls._instance = super().__new__(cls)return cls._instancedef __init__(self):self.value = "Singleton Value"instance1 = SingletonClass()
instance2 = SingletonClass()print(instance1 is instance2)  # 输出: True

总结

单例模式在Python中有多种实现方式,每种方式都有其优缺点。选择哪种方式取决于具体的应用场景和需求。通常情况下,使用模块或装饰器是最简单和最常见的方式。


http://www.ppmy.cn/ops/154659.html

相关文章

HTML5+SVG+CSS3实现雪中点亮的圣诞树动画效果源码

源码介绍 这是一款基于HTML5SVGCSS3实现雪中点亮的圣诞树动画效果源码。画面中的圣诞树矗立在雪地中,天上飘落着雪花。当鼠标滑过圣诞树时,可见到圣诞树上的灯光闪烁,同时左下角探出雪怪模样的半个脑袋,四处张望着。整体画面栩栩…

Java算法——排序

目录 引言1. 插入排序1.1 基本思想1.2 直接插入排序1.3 希尔排序 2. 选择排序2.1 基本思想2.2 直接选择排序2.3 直接选择排序变种2.4 堆排序 3. 交换排序3.1 基本思想3.2 冒泡排序3.3 快速排序3.3.1 快速排序的基本结构3.3.2 Hoare法3.3.3 挖坑法3.3.4 双指针法 3.4 快速排序非…

绘制决策树尝试2 内含添加环境变量步骤

目录 step1 ai码 ai改 step2 下面就是环境配置问题 “ExecutableNotFound: failed to execute WindowsPath(‘dot’), make sure the Graphviz executables are on your systems’ PATH” dot -v愣是没有​编辑 graphviz安装指导 对于Windows用户: 对于Lin…

Effective Python:(10)

Effective Python提供90条新颖的Python3编程技巧,可以让我们写程序更加灵活,代码更加整洁而易于维护,这对于商业化系统代码的重要性不言而喻。 前面两条主要介绍切片的实用好玩的用法,这一条里反而建议不用切片,这是什…

Ansible自动化运维实战--通过role远程部署nginx并配置(8/8)

文章目录 1、准备工作2、创建角色结构3、编写任务4、准备配置文件(金甲模板)5、编写变量6、编写处理程序7、编写剧本8、执行剧本Playbook9、验证-游览器访问每台主机的nginx页面 在 Ansible 中,使用角色(Role)来远程部…

【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】1.27 线性代数王国:矩阵分解实战指南

1.27 线性代数王国:矩阵分解实战指南 #mermaid-svg-JWrp2JAP9qkdS2A7 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-JWrp2JAP9qkdS2A7 .error-icon{fill:#552222;}#mermaid-svg-JWrp2JAP9qkdS2A7 .erro…

记录使用EasyWeChat做微信小程序登陆和其他操作

1.微信小程序登陆 关于后端:fastadmin加密生成token-CSDN博客 思路: 通过easywechatfastadmin, (1) 用户端登陆(获取code) -> 请求后端接口获取session_key -> 用户端保存session_key…

基于nodejs+json+websocket+html的聊天应用

实现 html <html lang"zh-CN"><head><meta charset"UTF-8"><title>Instant Messaging</title><!-- 引入Bootstrap CSS --><link href"https://cdn.jsdelivr.net/npm/bootstrap5.3.0/dist/css/bootstrap.min.…