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