装饰器用来扩充函数,有的语言用装饰器来写父类的子类
python中装饰器主要用来扩充函数,并不用来写子类
@的作用是使得以函数作为参数的闭包有一个更为简洁的表达
例1:
def plus1(x):
return x+1
def get_result(func):
def multiply(x1):
return func(x1)*5
return multiply
f = get_result(plus1) # f = multiply,且multiply函数体中的func为plus1
print(f(3))
输出 20
例2:把f换成plus1,便相当于扩充了plus1函数
def plus1(x): # 1
return x+1
def get_result(func):
def multiply(x1):
return func(x1)*5
return multiply
plus1 = get_result(plus1) # plus1 = multiply,且multiply函数体中的func为1处的plus1
print(plus1(3)) # 此时的plus1不再是1处的plus1,相当于扩充了1处的plus1
例3:用@简化语句plus1 = get_result(plus1)
def get_result(func):
def multiply(x1):
return func(x1)*5
return multiply
@get_result #即把下一行定义的函数作为参数传递给get_result,并把返回的函数命名为下一行定义的函数名
def plus1(x): # 1
return x+1
print(plus1(3)) # 此时的plus1不再是1处的plus1,而是例2中最后两行的plus1
输出:20
例4:多个修饰器同时修饰一个函数
最终的结果与修饰器的顺序有关
1、
def get_result(func):
def multiply(x1):
return func(x1)*5
return multiply
def get_result2(func):
def minus(x2):
return func(x2)-9
return minus
@get_result
@get_result2
def plus1(x):
return x+1
plus1(3)
输出为:-25 计算过程:((x+1)-9)*5
相当于:
def plus1(x):
return x+1
def get_result(func):
def multiply(x1):
return func(x1)*5
return multiply
def get_result2(func):
def minus(x2):
return func(x2)-9
return minus
plus1 = get_result2(plus1) # 把plus1作为参数传递给离plus1最近的装饰器get_result2,并把返回的函数命名为plus1
plus1 = get_result(plus1) # 把新的plus1作为参数传递给第二近的装饰器get_result,并把返回的函数命名为plus1
plus1(3)
输出为-25
2、调换修饰器的位置
def get_result(func):
def multiply(x1):
return func(x1)*5
return multiply
def get_result2(func):
def minus(x2):
return func(x2)-9
return minus
@get_result2
@get_result
def plus1(x):
return x+1
plus1(3)
输出为 11 计算过程:(x+1)*5-9
相当于:
def plus1(x):
return x+1
def get_result(func):
def multiply(x1):
return func(x1)*5
return multiply
def get_result2(func):
def minus(x2):
return func(x2)-9
return minus
plus1 = get_result(plus1)
plus1 = get_result2(plus1)
plus1(3)
输出为11