python多个装饰器的执行顺序解析

举例

def f_out1(f1):
    print('我是装饰器1')
    def f_in1():
        print('我是装饰器1的内嵌函数')
        f1()
    return f_in1
#装饰器2
def f_out2(f2):
    print('我是装饰器2')
    def f_in2():
        print('我是装饰器2的内嵌函数')
        f2()
    return f_in2
@f_out1
@f_out2
def f():
    print('我是f')
f()

运行结果

我是装饰器2
我是装饰器1
我是装饰器1的内嵌函数
我是装饰器2的内嵌函数
我是f

分析

1)可以直接理解装饰顺序是自下而上的
2)深入解析

 @f_out1
 @f_out2
 def f():
     print('我是f')

此段代码等效于 f = f_out1(f_out2(f))
这里要注意的是装饰器1的参数,内嵌函数,装饰器2的参数和内嵌函数各指向什么。

分析f = f_out1(f_out2(f)):
第一步:首先f_out2( f )先执行, print(‘我是装饰器2’) 就会执行,输出我是装饰器2。然后装饰器2的参数f2指向的就是f,然后返回装饰器2 的内嵌函数f_in2。
第二步:随后f_in2就会作为参数传入装饰器1,即会执行f_out1( f_in2 ),然后 print(‘我是装饰器1’) 就会执行,输出我是装饰器1。这时候装饰1的参数 f1 就指向了装饰器2的内嵌函数,而装饰器1的内嵌函数 f_in 就会传给等号左边的变量f

对 f() 的执行进行分析
1)有上面的分析可以知道此时f指向的是装饰1的内嵌函数,f() 执行即装饰器1的内嵌函数执行,然后下面代码将执行

def f_in1():
            print('我是装饰器1的内嵌函数')
            f1()

首先打印我是装饰器1的内嵌函数,输出我是装饰器1的内嵌函数,然后执行 f1()
2)注意f1 指向的是装饰器2的内嵌函数 f_in2 ,所以f1() 执行就是装饰器2的内嵌函数执行,即执行下面的代码

def f_in2():
            print('我是装饰器2的内嵌函数')
            f2()

首先打印我是装饰器2的内嵌函数,输出我是装饰器2的内嵌函数,然后执行 f2()
3)注意这里的f2 指向的是函数f ,所以函数 f 就会执行

  def f():
        print('我是f')

打印 我是f

最终打印结果就是

    我是装饰器2
    我是装饰器1
    我是装饰器1的内嵌函数
    我是装饰器2的内嵌函数
    我是f

你可能感兴趣的:(python,python,装饰器)