前言:
装饰器用于装饰某些函数或者方法,或者类。可以在函数执行之前或者执行之后,执行一些自定义的操作。
1、定义:装饰器就是一个函数,为新定义的函数。把原函数嵌套到新函数里面。以后就可以在执行新函数的过程中,同时执行旧函数,实现自定义操作。
装饰器的语法:
2、应用装饰器:@符号
1.1 无参数的装饰器
#装饰器架构: def outter(func): def inner(): print('hello world') print('hello world') print('hello world') r=func() print('end') print('end') print('end') return r return inner @outter def f1(): print('F1') >>> hello world hello world hello world F1 end end end
#开放封闭原则:不在原函数的修改代码基础上,实现函数执行前后新的功能 #装饰器架构: def outter(func): #原来那个f1函数 def inner(): print('hello world') print('hello world') print('hello world') #原f1函数 r=func() #r=None r=f1() print('end') print('end') print('end') return r #f1=inner →f1()=inner() return inner #@outter def f1(): print('F1') #1、执行outter函数,并且将其下面的函数名(f1)当做参数传入装饰器内:f1=func #2、将outter的返回值,重新赋值给f1→相当于f1执行另一个函数【相当于f1=inner内存地址】所以f1()相当于执行inner() #新f1函数拿到一个return值:r f1=r #总结: # 把原函数分装到另一个函数里面。在不改变原函数的基础上。在原函数执行前,后操作其他内容。 #拆解过程 f2=outter(f1) #f2=inner()的内存地址 result=f2() #执行inner函数,并把返回值赋值给result print(result) #打印执行结果 #然后把f1进行重新赋值。f1=f2 相当于:f1执行inner函数 >>> hello world hello world hello world F1 end end end None
总结:
1、只要函数应用上装饰器,那么函数就会被重新定义,重新定义为装饰器的内层函数
1.2 带2个参数的装饰器
缺点:
原函数有几个参数,装饰器就得有几个参数,很不方便。所以可以考虑引入可变参数和关键字参数。*args,**kwargs.这样可以接受无限多的参数。
这样无法满足对于参数的灵活控制。希望写一个装饰器就可以应用到多个函数。
如果inner函数可以接收任意个参数的话,就无需其他函数强制修改为何装饰器一致参数的工作。
1.3、多个参数的装饰器
通过装饰器可变参数,可以解决大部分参数问题。
不足点:只能实现多个函数调用一个装饰器。如果一个函数调用多个装饰器?
1.4、一个函数调用多个装饰器。
1.5、装饰器流程梳理
①、函数应用一个装饰器
原函数等价于→inner函数。func是原来的index函数
@outer的意思:
1、执行outer函数,将index函数作为参数传递。
2、将outter的返回值。重新赋值给index
执行流程:
单层:
做个类比:
@outter+index=inner函数
两层装饰器函数