python 中多个装饰器的执行顺序

python 中多个装饰器的执行顺序:

def wrapper1(f1):
    print('in wrapper1')
    def inner1(*args,**kwargs):
        print('in inner1')
        ret = f1(*args,**kwargs)
        return ret
    return inner1

def wrapper2(f2):
    print('in wrapper2')
    def inner2(*args,**kwargs):
        print('in inner2')
        ret = f2(*args,**kwargs)
        return ret
    return inner2

def wrapper3(f3):
    print('in wrapper3')
    def inner3(*args,**kwargs):
        print('in inner3')
        ret = f3(*args,**kwargs)
        return ret
    return inner3

@wrapper1
@wrapper2
@wrapper3
def func():
    print('in func')
func()
# in wrapper3
# in wrapper2
# in wrapper1
# in inner1
# in inner2
# in inner3
# in func
#装饰器函数在被装饰函数定义好后立即执行。多个装饰器的调用顺序是自下往上的。
# 被装饰函数执行时,装饰器的执行顺序是从上往下的。

分析:
 func = wrapper3(func)  ---> 先打印'in wrapper3', func = inner3 ,f3 = func
 func = wrapper2(func) --->即 inner3 = wrapper2(inner3) ---> 先打印'in wrapper2', inner3 = inner2 ,f2 = inner3  --> func = inner2
 func = wrapper1(func) --->即  inner2 = wrapper1(inner2) --->先打印'in wrapper1',  inner2 = inner1 ,f1 = inner2  --> func = inner1
 执行 func() 即执行执行 inner1() ,先打印 'in inner1',再执行 f1(),即执行inner2()
 即执行inner2() ,先打印 'in inner2',再执行 f2(),即执行inner3()
 即执行inner3() ,先打印 'in inner3',再执行 f3(),即执行func(),打印 'in func '

猜你喜欢

转载自www.cnblogs.com/xiaomage666/p/10990301.html