python装饰器的作用就是在不想改变原函数代码的情况下,增加新的功能.主要应用了python闭包的概念,现在用1个小例子说明
import time
def foo():
time.sleep(1)
def bar():
time.sleep(2)
def show_time(f):
def inner():
start_time = time.time()
f()
end_time = time.time()
print(end_time-start_time)
return inner
#show_time(f) is a decoration function
foo = show_time(foo)
bar = show_time(bar)
foo()
bar()
上面的代码定义了两个函数foo()和bar(). 通过装饰器函数show_time(f),在其内部定义了另一个闭包函数inner(),再通过foo=show_time(foo),bar=show_time(bar)语句将foo()和bar()函数同装饰器函数关联起来,从而实现了不改变foo()和bar()函数代码,增加打印程序执行时间的功能.程序的执行结果如下:
1.0011370182
2.00142788887
显然,程序在没有改变原函数的情况下,实现了调用原函数显示程序运行时间的功能.