【Python】 Python 中实现单例模式?

在 Python 中,实现单例模式通常有多种方法。以下是使用类装饰器实现单例模式的方法:

```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:

def init(self):

self.value = 0

def increment(self):

self.value += 1

class AnotherClass:

@staticmethod

def my_static_method():

print("This is a static method")

@singleton

class AnotherSingletonClass:

def init(self):

self.value = 0

def increment(self):

self.value += 1

Test the singleton classes

if name == "main":

my_instance = MyClass()

another_instance = AnotherClass()

another_singleton_instance = AnotherSingletonClass()

my_instance.increment()

another_instance.my_static_method()

another_singleton_instance.increment()

print(my_instance.value) # Output: 1

print(another_instance is AnotherClass.my_static_method()) # Output: True

print(another_singleton_instance.value) # Output: 1

```

在这个例子中,我们定义了一个类装饰器 `singleton`,它接受一个类作为参数,并返回一个单例对象。`singleton` 装饰器使用字典 `instances` 来存储已经创建的实例。当我们尝试创建类的实例时,如果该类已经在 `instances` 字典中,则返回已有的实例;否则,创建新的实例并存储在 `instances` 字典中。

我们还定义了两个类 `MyClass` 和 `AnotherClass`,它们分别具有一个实例方法和静态方法。我们还定义了两个单例类 `MyClass` 和 `AnotherSingletonClass`,它们具有相同的实例方法和静态方法。

在测试部分,我们创建了 `MyClass`、`AnotherClass` 和 `AnotherSingletonClass` 的实例,并调用了它们的实例方法和静态方法。从输出中可以看出,`MyClass` 和 `AnotherSingletonClass` 的实例方法输出了相同的值,这是因为它们是同一个类的实例;而 `AnotherClass` 的静态方法输出了与 `AnotherSingletonClass` 的静态方法相同的输出,这是因为它们都是同一个类的静态方法。

相关推荐
FL16238631292 小时前
[C#][winform]基于yolov8的水表读数检测与识别系统C#源码+onnx模型+评估指标曲线+精美GUI界面
开发语言·yolo·c#
cnxy1885 小时前
围棋对弈Python程序开发完整指南:步骤1 - 棋盘基础框架搭建
开发语言·python
落叶,听雪5 小时前
河南建站系统哪个好
大数据·人工智能·python
极客小云6 小时前
【生物医学NLP信息抽取:药物识别、基因识别与化学物质实体识别教程与应用】
python·机器学习·nlp
南_山无梅落6 小时前
12.Python3函数基础:定义、调用与参数传递规则
python
程序员-周李斌6 小时前
Java 死锁
java·开发语言·后端
JasmineWr7 小时前
CompletableFuture相关问题
java·开发语言
零雲7 小时前
java面试:知道java的反射机制吗
java·开发语言·面试
Jeremy爱编码7 小时前
实现 Trie (前缀树)
开发语言·c#
laocooon5238578867 小时前
插入法排序 python
开发语言·python·算法