Singleton 是一种设计模式,它确保类只能创建一个实例,并提供了一个全局访问点来获取该实例。在 Python 3.6 中,可以使用以下几种方式创建具有属性和方法的 Singleton:
def singleton(cls):
instances = {}
def wrapper(*args, **kwargs):
if cls not in instances:
instances[cls] = cls(*args, **kwargs)
return instances[cls]
return wrapper
@singleton
class MyClass:
def __init__(self, arg1, arg2):
self.arg1 = arg1
self.arg2 = arg2
def method(self):
print("Singleton method")
# 创建 Singleton 实例
obj1 = MyClass("arg1_value", "arg2_value")
obj2 = MyClass("arg1_value_2", "arg2_value_2")
# 访问属性
print(obj1.arg1)
print(obj2.arg2)
# 调用方法
obj1.method()
obj2.method()
这种方式使用了装饰器来包装原始类,创建一个字典来存储实例。如果实例不存在,则创建一个新的实例并存储在字典中,否则返回已存在的实例。
class Singleton(type):
_instances = {}
def __call__(cls, *args, **kwargs):
if cls not in cls._instances:
cls._instances[cls] = super().__call__(*args, **kwargs)
return cls._instances[cls]
class MyClass(metaclass=Singleton):
def __init__(self, arg1, arg2):
self.arg1 = arg1
self.arg2 = arg2
def method(self):
print("Singleton method")
# 创建 Singleton 实例
obj1 = MyClass("arg1_value", "arg2_value")
obj2 = MyClass("arg1_value_2", "arg2_value_2")
# 访问属性
print(obj1.arg1)
print(obj2.arg2)
# 调用方法
obj1.method()
obj2.method()
这种方式使用了元类来控制类的创建过程。在 __call__
方法中判断是否已经存在实例,如果不存在则创建一个新实例并存储在 _instances
字典中,否则返回已存在的实例。
无论是使用装饰器还是元类,上述代码均可实现具有属性和方法的 Singleton。然而,使用元类的方式更为灵活,可以在类定义阶段添加更多自定义逻辑。
关于推荐的腾讯云产品,腾讯云提供了多种云计算相关的产品,包括云服务器、云数据库、云存储、人工智能等。根据具体需求,可以选择使用腾讯云的产品来支持开发和部署。
云原生正发声
云+社区沙龙online [国产数据库]
云+社区技术沙龙[第27期]
云+社区技术沙龙[第16期]
数字化产业研学会第一期
云+社区技术沙龙[第20期]
技术创作101训练营
TC-Day
领取专属 10元无门槛券
手把手带您无忧上云