Python单例模式的三种实现方式

from functools import wraps


class Foo1(object):
    """单例模式 1 使用类方法"""

    __instance = None

    @classmethod
    def instance(cls):
        if cls.__instance:
            return cls.__instance

        else:
            obj = cls()
            cls.__instance = obj
            return cls.__instance


def test1():
    obj1 = Foo1.instance()
    obj2 = Foo1.instance()
    # id相同
    print(f'id(obj1)={id(obj1)}/id(obj2)={id(obj2)}')


class Foo2(object):
    """单例模式 2 基于__new__方法实现"""
    __instance = None

    def __init__(self):
        pass

    def __new__(cls, *args, **kwargs):
        if cls.__instance:
            return cls.__instance
        else:
            obj = object.__new__(cls)
            cls.__instance = obj
            return cls.__instance


def test2():
    obj1 = Foo2()
    obj2 = Foo2()
    # id相同
    print(f'id(obj1)={id(obj1)}/id(obj2)={id(obj2)}')


def Singleton(cls):
    _instance = {}

    @wraps(cls)
    def _singleton(*args, **kwargs):
        if cls not in _instance:
            _instance[cls] = cls(*args, **kwargs)
        return _instance[cls]

    return _singleton


@Singleton
class Foo3(object):
    """单例模式 3 基于装饰器"""
    count = 0

    def __new__(cls, *args, **kwargs):
        cls.count += 1

    def __init__(self):
        pass


def test3():
    obj1 = Foo3()
    obj2 = Foo3()
    # id相同
    print(f'id(obj1)={id(obj1)}/id(obj2)={id(obj2)}')


if __name__ == '__main__':
    test1()
    test2()
    test3()

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

WUYANGEZRA

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值