python单例模式

单例模式(Singleton Pattern)是一种设计模式,它确保一个类只有一个实例,并提供一个全局访问点来访问该实例。这个模式通常用于那些需要在整个应用程序中共享一个公共资源的情况,例如日志记录器、数据库连接、线程池等。

单例模式的主要特点包括:

单一实例:一个类只能有一个实例存在。

全局访问点:提供一个公共的访问点,允许其他对象在程序中访问这个单例实例。

在 Python 中实现单例模式的方法有多种,以下是其中两种常见的方式:

1. 使用模块级别的变量

通过模块的方式实现单例模式是 Python 中最简单的方式之一,因为 Python 的模块在程序生命周期内只会被加载一次,所以模块级别的变量也只会被创建一次。

python

Copy code

python 复制代码
# singleton.py

class Singleton:
    def __init__(self):
        # 初始化代码
        pass

# 创建单例实例
singleton_instance = Singleton()

其他模块可以直接导入这个模块,并访问其中的 singleton_instance,这样就可以得到单例的实例了:

python 复制代码
# other_module.py

from singleton import singleton_instance

# 使用单例实例
print(singleton_instance)

2. 使用装饰器(Decorator)

另一种常见的方式是使用装饰器来确保一个类只有一个实例。下面是一个简单的装饰器实现单例模式的示例:

python 复制代码
# 定义一个装饰器 singleton,用于实现单例模式
def singleton(cls):
    # 创建一个字典用于存储单例实例
    instances = {}

    # 定义一个内部函数,用于获取单例实例
    def get_instance(*args, **kwargs):
        # 检查类是否已经在 instances 字典中
        if cls not in instances:
            # 如果不存在,则创建一个新的实例并存储在 instances 中
            instances[cls] = cls(*args, **kwargs)
        # 返回类的单例实例
        return instances[cls]

    # 返回内部函数作为装饰器
    return get_instance

# 使用装饰器 singleton 来装饰 Logger 类,使其成为单例模式
@singleton
class Logger:
    def __init__(self):
        # 初始化代码,这里可以添加日志记录器的初始化逻辑
        pass

# 使用单例实例
# 当第一次创建 Logger 实例时,会调用装饰器内部的 get_instance 函数,
# 在此之后,再次创建 Logger 实例时将直接返回第一次创建的实例
logger = Logger()

这里定义了一个 singleton 装饰器,它可以用来装饰一个类。装饰后的类在实例化时,会检查是否已经存在实例,如果存在则直接返回,如果不存在则创建新实例并返回。

无论是哪种方式,单例模式都可以确保在整个应用程序中只有一个实例存在,并且可以通过全局访问点方便地访问到这个实例。

相关推荐
cpp_learners28 分钟前
银河麒麟V10+飞腾FT-2000/4处理器+QT源码静态编译5.14.2指南
开发语言·qt
野生技术架构师36 分钟前
1000道互联网大厂Java岗面试原题解析(八股原理+场景题)
java·开发语言·面试
YuanDaima204843 分钟前
[CrewAI] 第15课|构建一个多代理系统来实现自动化简历定制和面试准备
人工智能·python·面试·agent·crewai
qqty12171 小时前
Java进阶学习之路
java·开发语言·学习
WHS-_-20221 小时前
Python 算法题学习笔记一
python·学习·算法
gCode Teacher 格码致知1 小时前
Javascript提高:get和post等请求,对于汉字和空格信息进行编码的原则-由Deepseek产生
开发语言·前端·javascript·node.js·jquery
黑眼圈子1 小时前
总结一下用Java做算法的常用类和方法
java·开发语言·算法
码界筑梦坊1 小时前
353-基于Python的大湾区气候数据可视化分析系统
开发语言·python·信息可视化·数据分析·django·vue·毕业设计
如何原谅奋力过但无声2 小时前
【chap11-动态规划(上 - 基础题目&背包问题)】用Python3刷《代码随想录》
数据结构·python·算法·动态规划
云姜.2 小时前
JSON Schema使用
python·json