demo:
1 #装饰器其实就是对闭包的使用
2 print('haha嘻嘻')3 defhot():4 print('知道')5 defdec(fun):6 print("call dec")7 defin_dec():8 print("call in_dec")9 #fun()
10 #必须加上返回语句,不然的话会默认返回None
11 returnin_dec12 hot()13 @dec14 deffun():15 print("call fun")16
17 fun()18 #注意上面的返回语句加上还有不加上的时候这一句执行的区别
19 print(type(fun))20 fun()
运行结果:
1 haha嘻嘻2 知道3 call dec4 call in_dec5
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函数返回的数据