了解装饰器的作用
装饰器是用来给某一程序加上一些功能,可做到不修改被装饰函数源代码,也不改变其调用方式。python装饰器就是用于拓展原来函数功能的一种函数,这个函数的特殊之处在于它的返回值也是一个函数
上代码
我们首先假设要执行一段代码输出 “并不是为了改变世界”
#主功能函数
def say():
print("并不是为了改变世界")
现在客户需要改需求了,需要在每一次调用say()之前都要输出一句 “我们一直努力”,在say()之后要输出一 句 “而是让世界不再改变我们”。这个时候我们该如何处理呢?这个时候就需要装饰器了
#装饰器函数
def saybefore(func):
def wrapper(*args,**kergs):
print('我们一直努力')
return func(*args,**kergs)
return wrapper
def sayafter(func):
def wrapper(*args,**kergs):
result=func(*args,**kergs)
print('而是让世界不再改变我们')
return result
return wrapper
这时两个装饰器函数就已经完成了,那怎么用呢?
#把主功能函数前改成
@saybefore
@sayafter
def say():
print("并不是为了改变世界")
#调用say()
say()
这样就可以实现这个功能了。
运行顺序
在python中的@的装饰函数时自下而上执行的,也就是说以上代码相当于f=saybefore(sayafter(say)) ,首先应该分清楚函数的定义和运行单单只有函数名时是不会运行的像say,只有在给它传参时才会运行像say(),所以开始是把say传到sayafter,然而sayafter 也没有运行,只是又定义了一个函数对象传给了saybefore,这时saybefore开始执行,所以先输出了一个--“我们一直努力”,而运行完输出之后,是一个从上层函数传进来的func()==sayafter,所以在执行sayafter(),这时我们可以看到执行sayafter()的第一条语句是执行func()=say(),所以先执行完say输出--"并不是为了改变世界",执行完之后应该是执行sayafter()的输出语句--“而是让世界不再改变我们”。最后执行完sayafter之后,在执行saybefore。
因此最先执行完的是say(),然后是sayafter(),最后是saybefore()。