采用__call__ 实现装饰器模式

装饰器模式在实现中也是很常见的:比如手机贴膜,手机壳 都是为了给手机增加一些额外功能 增加耐操

装饰器模式的本质就是对对象二次包装,赋额外功能

__call__

__call__是python魔术方法——可调用对象,指的是可以实现一个对象实例以函数的方式来调用。

class Test:
    def __call__(self, *args, **kws):
        print(*args, **kws)


t = Test()

t("你好","hello word")

 

无参数装饰器

现在有一个out函数,用于打印输出。现在要想要统计这函数执行了多少次

class Count:
    def __init__(self,func):
        self.func = func
        self.i = 0

    def __call__(self,*args,**kws):
        self.i += 1
        print(f"执行次数:{self.i}")
        return self.func(*args,**kws)

@Count
def out(s):
    print(s)

out("你好")
out("呵呵")

'''
相当于
out = Count(out)   
out()
把函数传入Count类中,创建对象实例 然后利用__call__魔术方法实现执行可调用对象
'''

 

有参数装饰器

现在Count类有一个属性color,给统计数值上颜色。

class Count:
    def __init__(self, color):
        self.color = color
        self.i = 0

    def __call__(self, func):
        self.func = func
        return self.__callback

    def __callback(self, *args, **kw):
        self.i += 1
        print(f"执行次数:{self.color} {self.i}")
        return self.func(*args, **kw)


@Count("红色")   # 接收参数
def test(s):
    print(s)


test("哈哈") 

'''
等价于
d = Count("红色")
test = d(test)
test("哈哈")
'''
test(
"哈哈") test("哈哈")

''' 输出
执行次数:红色 1
哈哈
执行次数:红色 2
哈哈
执行次数:红色 3
哈哈
'''

 

posted @ 2019-11-23 12:41  破壳而出的蝌蚪  阅读(354)  评论(0编辑  收藏  举报