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

哪位大神能解释一下吗,越详细越好

def fn(*args, **kw):

        t1 = time.time()

        r = f(*args, **kw)

        t2 = time.time()


正在回答

4 回答

f()来自被修饰的函数...定义修饰函数的时候def performance(f),括号里的东西

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

定义了一个函数 它可以任意传入多个参数 用t1记录开始执行函数时的时间 用R接受调用f()后的结果 在用t2 记录函数调用后的时间 t2-t1大致就可以表示执行该函数所用的时间

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

qq_尊爵Miku_0

请问用R接受调用f()后的结果,f() 是从哪来的?定义的是fn()不是吗?小白一枚
2016-09-06 回复 有任何疑惑可以回复我~

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)


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

代码贴全再来问问题

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

举报

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

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

进入课程

哪位大神能解释一下吗,越详细越好

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