为了账号安全,请及时绑定邮箱和手机立即绑定

最后输出时间显示为0,但是同样通过了,究竟这样对不对

import time


def performance(f):

    def fn(*args, **kw):

        t1 = time.time()

        t2 = time.time()

        print 'call %s() in %fs' % (f.__name__, (t2 - t1))

        return f(*args, **kw)

    return fn


@performance

def factorial(n):

    return reduce(lambda x,y: x*y, range(1, n+1))


print factorial(10)


正在回答

2 回答

如果需要获取耗时 那么需要在startTime 和 endTime之间运行被装饰的方法  

题目上并不是让输出耗时 只是需要输出call time 调用方法的时间

0 回复 有任何疑惑可以回复我~
#1

慕妹5270689 提问者

非常感谢!
2017-04-06 回复 有任何疑惑可以回复我~

你没有调用原函数,所以t1==t2,所以t2-t1=0,所以显示的时间为0,要计算调用函数花费多少时间,就是记录调用前的时间t1,运行函数,记录调用后的时间t2,t2-t1即为该函数运行消耗的时间。

0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
python进阶
  • 参与学习       255665    人
  • 解答问题       2949    个

学习函数式、模块和面向对象编程,掌握Python高级程序设计

进入课程

最后输出时间显示为0,但是同样通过了,究竟这样对不对

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信