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 装饰器,它可以用来装饰一个类。装饰后的类在实例化时,会检查是否已经存在实例,如果存在则直接返回,如果不存在则创建新实例并返回。

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

相关推荐
一个小白12 分钟前
C++——list模拟实现
开发语言·c++
bug总结2 分钟前
新学一个JavaScript 的 classList API
开发语言·javascript·ecmascript
Nicole Potter9 分钟前
请说明C#中的List是如何扩容的?
开发语言·面试·c#
liuyuzhongcc11 分钟前
List 接口中的 sort 和 forEach 方法
java·数据结构·python·list
鸟哥大大19 分钟前
【Python】pypinyin-汉字拼音转换工具
python·自然语言处理
jiugie28 分钟前
MongoDB学习
数据库·python·mongodb
十八朵郁金香1 小时前
通俗易懂的DOM1级标准介绍
开发语言·前端·javascript
阿尔法波1 小时前
python与pycharm如何设置文件夹为源代码根目录
开发语言·python·pycharm
xing25161 小时前
pytest下allure
开发语言·python·pytest
眸笑丶1 小时前
使用 Python 调用 Ollama API 并调用 deepseek-r1:8b 模型
开发语言·python