demo:
1 # 装饰器其实就是对闭包的使用 2 print('haha嘻嘻') 3 def hot(): 4 print('知道') 5 def dec(fun): 6 print("call dec") 7 def in_dec(): 8 print("call in_dec") 9 # fun() 10 # 必须加上返回语句,不然的话会默认返回None 11 return in_dec 12 hot() 13 @dec 14 def fun(): 15 print("call fun") 16 17 fun() 18 # 注意上面的返回语句加上还有不加上的时候这一句执行的区别 19 print(type(fun)) 20 fun()
运行结果:
1 haha嘻嘻 2 知道 3 call dec 4 call in_dec 5 <class 'function'> 6 call in_dec
执行顺序:
2——12——3,4——13——5,6——11——17——7,8——19——20——7,8
如果第7行将‘ # ’ 号去掉
则执行顺序:
2——12——3,4——13——5,6——11——17——7,8,9——14,15——19——20——7,8,9——14,15
发现:
1. python从上到下执行程序
2. 在装饰器前如果有需要执行的语句时,先完成前面语句的执行,在执行装饰器、
3. 执行装饰器时,必须携带参数【根据多次实验,必须含参,必须返回内容(返回的内容可以是值也可以是函数,是返回给装饰器装饰的函数的,也就是复制给装饰器装饰的函数的,所以必须返回,否则报错),而且该参数名可以随便取,但参数都是代表装饰器装饰的函数】
注意:如果装饰器返回内容为装饰器携带的参数,则返回的内容仍然为装饰器装饰的函数的,即当执行装饰器装饰的函数时,仍然执行本身
4. 再继续往下执行
原理:
在第三步中,@hahah => fun = dec(fun) ,到时候fun执行时是执行dec函数返回的数据