python - 如何在python中创建带有参数的单例类
问题描述
我正在寻找正确的方法来创建一个在第一次创建时接受参数的单例类。我的研究引导我采用 3 种不同的方式:
元类
class Singleton(type):
instance = None
def __call__(cls, *args, **kwargs):
if cls.instance is None:
cls.instance = super(Singleton, cls).__call__(*args, **kwargs)
return cls.instance
class ASingleton(metaclass=Singleton):
pass
__新的__
class Singleton(object):
instance = None
def __new__(cls, *args, **kwargs):
if cls.instance is None:
cls.instance = super().__new__(cls, *args, **kwargs)
return cls.instance
装饰器
def Singleton(myClass):
instances={}
def getInstance(*args, **kwargs):
if myClass not in instances:
instances[myClass] = myClass(*args, **kwargs)
return instances[myClass]
return getInstance
@Singleton
class SingletonTest(object):
pass
它们都工作得很好,但是当涉及到启动时(比如在普通类中使用__init__),我想不出正确的方法来实现它。我能想到的唯一解决方案是以这种方式使用元类方法:
class Singleton(type):
instance = None
def __call__(cls, *args, **kwargs):
if cls.instance is None:
cls.instance = super(Singleton, cls).__call__(*args, **kwargs)
return cls.instance
class ASingleton(metaclass=Singleton):
def __init__(self,j):
self.j=j
我不知道这是否是创建接受参数的单例的正确方法。
解决方案
我发现实现 Singleton 的最佳方法是使用元类:
class Singleton (type):
_instances = {}
def __call__(cls, *args, **kwargs):
if cls not in cls._instances:
cls._instances[cls] = super(Singleton, cls).__call__(*args, **kwargs)
return cls._instances[cls]
# Python 2
class MyClass():
__metaclass__= Singleton
# Python 3
class MyClass(metaclass=Singleton):
pass
推荐阅读
- python - 如何计算 STEP 文件中包含的实体几何的质心?
- dart - 如何随着媒体屏幕尺寸的变化关闭材料抽屉?
- c - 为什么连续声明的指针变量按地址递减的顺序存储在内存中?
- python - 如何在字符串中放置随机点?
- blockchain - 字节码的存储位置
- python - Cartopy 示例产生分段错误
- c# - ASP.NET 错误:System.TypeLoadException 无法加载字段“Microsoft.Owin.Security.ActiveDirectory”的类型
- batch-file - 如何在批处理文件中添加超时或暂停以每 X 秒打开一次 Firefox 选项卡
- javascript - RegexReplace 和 RangeToTable 问题
- java - 为什么我的 logback/logstash json 编码器配置在 Mac OS 上不起作用?