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

谁能把代码逐行解析一下?

import time

def performance(f):

    def fn(*args,**kw):

        t1 = time.time()

        r = f(*args, **kw)

        t2 = time.time()

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

        return r

    return fn

@performance

def factorial(n):

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

print factorial(10)


正在回答

2 回答

先定义了一个装饰器performance:

     在其中定义一个函数fn:先记录运行前的时间t1,然后用r先让函数运行,在记录运行后的时间t2,之后输出相应信息(f.__name__输出调用装饰器的函数名称:factorial)

最后调用装饰器,函数factorial返回值为10的阶乘,输出函数返回值同时输出装饰器返回值

          

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

有没有大神解答一下,装饰器里的 r = f(*args,**kw), 我知道参数是传进来了,但是 f函数不是没定义吗,那这个计算的时间差值还是函数factorial运行的时间吗?  0.0

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

举报

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

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

进入课程

谁能把代码逐行解析一下?

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