标签:前言 现在 输出 工具类 测试 语言 mrp __init__ src
单例模式应该是所有接触的设计模式初学者第一个听过的设计模式,这个模式应该是所有设计模式中最简单的一个模式了。值得注意的是,许多开发者将单例模式视为一种反模式,因此单例模式在 Python 中的使用频率现在越来越少了。
反模式(英文:Anti-patterns或pitfalls), 是指用来解决问题的带有共同性的不良方法。它们已经经过研究并分类,以防止日后重蹈覆辙,并能在研发尚未投产时辨认出来。软件开发中公认的反模式
单例模式最常使用的场景就是连接数据库以及日志等等,单例模式使用的场景通常有以下几个特点
class SingletonMeta(type):
_instances = {}
def __call__(cls, *args, **kwargs):
if cls not in cls._instances:
instance = super().__call__(*args, **kwargs)
cls._instances[cls] = instance
return cls._instances[cls]
class Singleton(metaclass=SingletonMeta):
def some_action(self):
pass
if __name__ == "__main__":
s1 = Singleton()
s2 = Singleton()
if id(s1) == id(s2):
print("Singleton works")
else:
print("Singleton failed")
看一下输出:
Singleton works
上面的单例模式可能会在多线程环境中出错,所以为了解决这个问题,我们将单例模式再升级一下
from threading import Lock, Thread
class SingletonMeta(type):
_instances = {}
_lock: Lock = Lock()
def __call__(cls, *args, **kwargs):
with cls._lock:
if cls not in cls._instances:
instance = super().__call__(*args, **kwargs)
cls._instances[cls] = instance
return cls._instances[cls]
class Singleton(metaclass=SingletonMeta):
value: str = None
def __init__(self, value: str) -> None:
self.value = value
def some_action(self):
pass
def test_singleton(value: str) -> None:
singleton = Singleton(value)
print(singleton.value)
if __name__ == "__main__":
# 由于是单例模式,预期两个线程输出的结果应该一样,都是第一个 FOO
process1 = Thread(target=test_singleton, args=("FOO",))
process2 = Thread(target=test_singleton, args=("BAR",))
process1.start()
process2.start()
看一下输出结果:
FOO
FOO
标签:前言 现在 输出 工具类 测试 语言 mrp __init__ src
原文地址:https://www.cnblogs.com/leetao94/p/13320769.html