Python使用闭包,减少重复,实现计算不同函数运行时间效果

实现计算不同函数运行时间,最先想到的方法是在不同函数运行前后分别计时,然后后计算2者的时间差就可以了,然而代码就会有大量重复的计时语句,使用Python函数闭包的方法就可以快速解决这个问题,代码实现如下,供需要的参考。

import time
import random


def timer(func):
    """装饰器:打印函数耗时"""    
    def decorated(*args, **kwargs):        
        st = time.perf_counter()        
        ret = func(*args, **kwargs)        
        print('%s time cost:  {} seconds'.format(time.perf_counter()- st) % str(func))        
        return ret    
    return decorated


@timer
def random_sleep():   
    """随机睡眠一小会儿"""  
    time.sleep(random.random())


@timer
def add(a, b):
    return a + b


random_sleep()
c = add(101, 304)
print(c)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值