要理清楚多个装饰器的执行顺序,对于很多人来说是噩梦一般的存在,但是,这个其实一句话就能说明白的,先看下面代码:
def out_1(func): print('i am out_1') def inner_1(): print('i am inner_1') return func() return inner_1 def out_2(func): print('i am out_2') def inner_2(): print('i am inner_2') return func() return inner_2 @out_1 @out_2 def func_print(): print('i am func_print') func_print()
定义了两个装饰器函数,out1,out2,执行结果如下:
i am out_2 i am out_1 i am inner_1 i am inner_2 i am func_print
好吧,一句话这么理解:装饰器,只对函数进行装饰,装饰器不对装饰器进行装饰,所以
1~~~~out2先装饰func_print函数,相当于执行func_print = out_2(func_print),所以先打印了 i am out_2,
2~~~~@out_2装饰完之后,@out1再对func_print进行装饰,并且此时的func_print已经指向了inner_2函数,所以@out_1对他进行装饰相当于func_print= out1(inner_2)这个时候就会执行"i am out_1"的打印,
3~~~~此时的func_print就指向了inner_1,就是两个装饰都装饰完毕了,最后一行代码调用了func_print(),所以就相当于调用了inner_1,这个时候打印"i am inner_1"
4~~~~打印完成之后执行到inner_1里的return func() 此时的func是inner_2,再执行inner_2打印‘I am inner_2’,
5~~~~而inner_2里还有return fun(),这时的func才是最初的func_print,最后打印‘i am func_print’
以上描述看似复杂,但是你如果能理解这个黑体加粗的话,装饰器装饰顺序就是so easy!!!!!有木有