zoukankan      html  css  js  c++  java
  • Python中的单例模式

    单例模式(Singleton Pattern)是一种常用的软件设计模式。主要目的是确保某一个类只有一个实例存在。
    所以适用于类实例在__init__ 方法中不含有初始化参数的情况。

    实现方式

    __new__ 实现

    class Single:
        _instance = {}
    
        def __new__(cls, *args, **kwargs):
            if cls not in cls._instance:
                cls._instance[cls] = super().__new__(cls, *args, **kwargs)
            return cls._instance[cls]
    
        def say(self, a, b):
            print(a + b)
    
    
    c1 = Single()
    c2 = Single()
    
    print(id(c1))
    print(id(c2))
    print(c1 is c2)
    print(c1.say(1, 2) is c2.say(1, 2))
    

    函数装饰器实现

    def singleton_func(cls):
        _instance = {}
    
        def inner(*args, **kwargs):
            if cls not in _instance:
                _instance[cls] = cls(*args, **kwargs)
            return _instance[cls]
    
        return inner
    
    
    @singleton_func
    class Cls02:
        def say(self, a, b):
            print(a+b)
    
    
    cls1 = Cls02()
    cls2 = Cls02()
    print(id(cls1) == id(cls2))
    cls1.say(1, 2)
    

    metaclass 实现

    class SingletonCall(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 Cls4(metaclass=SingletonCall):
    
        def add(self, a, b):
            return a + b
    
    
    p1 = Cls4()
    p2 = Cls4()
    print(id(p1) == id(p2))
    print(p2.add(1, 2) is p1.add(1, 2))
    

    类装饰器实现

    class SingletonCls:
        def __init__(self, cls):
            self._cls = cls
            self._instance = {}
    
        def __call__(self, *args, **kwargs):
            if self._cls not in self._instance:
                self._instance[self._cls] = self._cls(*args, **kwargs)
            return self._instance[self._cls]
    
    
    @SingletonCls
    class Cls2(object):
        pass
    
    
    cls1 = Cls2()
    cls2 = Cls2()
    print(id(cls1) == id(cls2))
    
  • 相关阅读:
    限制泛型可用类型
    泛型的常规用法(声明两个类型)
    一个类似于金字塔的图形
    Fibonacci数
    快来秒杀我
    奇偶数分离
    Background
    Financial Management
    HangOver
    Binary String Matching
  • 原文地址:https://www.cnblogs.com/jianjiacangcang/p/14950545.html
Copyright © 2011-2022 走看看