计时装饰器

装饰器

在不改变原有函数定义与调用情况下,为其增加新功能。

  • 核心思想:拦截
  • 外层函数价值:拦 --> 拦截对旧功能的调用
  • 内层函数价值:包 --> 将新旧功能包在一起
import time

def print_execute_time(func):
    def wrapper(*args, **kwargs):  # 合 --> 让调用旧功能的实参数量无限
        start_time = time.time()
        # func -- 旧功能
        re = func(*args, **kwargs)  # 拆  --> 将实参拆分后与旧功能的形参对应
        stop_time = time.time()
        # 新功能 -- 打印执行时间
        print(stop_time - start_time)
        return re
    return wrapper

@print_execute_time  # fun01 =  print_execute_time(fun01)
def fun01():
    time.sleep(2)  # 睡眠2秒,用于模拟计算2秒钟
@print_execute_time
def fun02(a):
    time.sleep(3)  # 睡眠3秒
    return "ok"

# fun01 = print_execute_time(fun01)# 调用外层函数,返回内层函数。
fun01()

# fun02 =  print_execute_time(fun02)# 调用外层函数,返回内层函数。
re = fun02(100)
print(re)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值