Python单例模式,附多种实现方案

在Python中实现单例模式,意味着一个类只能创建一个实例。单例模式在某些场景下非常有用,比如当你需要控制资源的访问,或者当你想确保全局只有一个对象实例时。下面是几种在Python中实现单例模式的方法:

1. 使用模块

Python的模块本身就是单例的,因为模块在第一次导入时初始化,之后的导入会直接使用已经加载的模块实例。因此,你可以简单地将你的单例对象作为模块级别的变量定义在一个模块中。

2. 使用__new__方法

可以通过覆盖类的__new__方法来确保只创建一个实例:

python 复制代码
class Singleton:
    _instance = None
    def __new__(cls, *args, **kwargs):
        if not cls._instance:
            cls._instance = super(Singleton, cls).__new__(cls, *args, **kwargs)
        return cls._instance

# 使用
singleton1 = Singleton()
singleton2 = Singleton()

# 检验
assert singleton1 is singleton2  # 为True,说明singleton1和singleton2是同一个实例

3. 使用装饰器

创建一个装饰器,用于装饰类,以确保只创建一个实例:

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 MyClass:
    pass

# 使用
my_class1 = MyClass()
my_class2 = MyClass()

# 检验
assert my_class1 is my_class2  # 为True,说明my_class1和my_class2是同一个实例

4. 使用基类

创建一个单例基类,其他类通过继承这个基类来成为单例:

python 复制代码
class SingletonBase:
    _instances = {}
    def __new__(cls, *args, **kwargs):
        if cls not in cls._instances:
            cls._instances[cls] = super(SingletonBase, cls).__new__(cls, *args, **kwargs)
        return cls._instances[cls]

class MyClass(SingletonBase):
    pass

# 使用
my_class1 = MyClass()
my_class2 = MyClass()

# 检验
assert my_class1 is my_class2  # 为True,说明my_class1和my_class2是同一个实例

这些方法各有特点,你可以根据自己的需求选择合适的实现方式。

相关推荐
少云清7 分钟前
【性能测试】15_JMeter _JMeter插件安装使用
开发语言·python·jmeter
光羽隹衡29 分钟前
机器学习——TF-IDF实战(红楼梦数据处理)
python·tf-idf
2401_894828122 小时前
从原理到实战:随机森林算法全解析(附 Python 完整代码)
开发语言·python·算法·随机森林
B站计算机毕业设计超人2 小时前
计算机毕业设计Python知识图谱中华古诗词可视化 古诗词情感分析 古诗词智能问答系统 AI大模型自动写诗 大数据毕业设计(源码+LW文档+PPT+讲解)
大数据·人工智能·hadoop·python·机器学习·知识图谱·课程设计
玄同7652 小时前
Python「焚诀」:吞噬所有语法糖的终极修炼手册
开发语言·数据库·人工智能·python·postgresql·自然语言处理·nlp
johnny2332 小时前
Python管理工具:包、版本、环境
python
羽翼.玫瑰2 小时前
关于重装Python失败(本质是未彻底卸载Python)的问题解决方案综述
开发语言·python
cdut_suye2 小时前
解锁函数的魔力:Python 中的多值传递、灵活参数与无名之美
java·数据库·c++·人工智能·python·机器学习·热榜
木头左2 小时前
指数期权备兑策略量化实现
python
小镇学者2 小时前
【python】python项目是如何部署到服务器上的
服务器·python·github