实现

极简化解释:在 Python 中类本身就是 type 的对象,而元类就是继承了 type 的类,仅此而已。

其实就是在初始化前检查一下当前类中是否存在一个实例,存在就返回。

1
2
3
4
5
6
7
8
9
class SingletonMeta(type):
def __init__(cls, *args, **kwargs):
super().__init__(*args, **kwargs)
cls._singleton_instance = None

def __call__(cls, *args, **kwargs):
if cls._singleton_instance is None:
cls._singleton_instance = super().__call__(*args, **kwargs)
return cls._singleton_instance

如果你想以继承的方式使这个类成为单例,可以再添加一个工具类。

1
2
class Singleton(metaclass=SingletonMeta):
__slots__ = ()

下面那句只是为了节省一点内存,可以用 sys.getsizeof 来验证这一点,这里不再赘述。如果你愿意的话,直接 pass 也可以。