装饰器的使用

学习目标

  • 能够说出装饰器的作用

1. 装饰器的使用场景

  1. 函数执行时间的统计
  2. 输出日志信息

2. 装饰器实现已有函数执行时间的统计

import time

# 装饰器函数
def get_time(func):
    def inner():
        begin = time.time()
        func()
        end = time.time()
        print("函数执行花费%f" % (end-begin))
    return inner


@get_time
def func1():
    for i in range(100000):
        print(i)


func1()

执行结果:


...
99995
99996
99997
99998
99999
函数执行花费0.329066

2. 小结

通过上面的示例代码可以得知装饰器的作用:

  • 在不改变已有函数源代码及调用方式的前提下,对已有函数进行功能的扩展。