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

根据执行顺序,执行装饰器的代码,再执行函数里面的代码,那是不是计算了两次阶乘?但是为什么根据log是执行了一次而已,只在装饰器里面调用的时候执行了

time
performance(fun):
    timeadd(*args,**kw):
        t=time.time()
        r=fun(*args,**kw)
        tt=time.time()
        %(fun.,tt-t)
        r
    timeadd
factorial(n):
    (x,y: x*y, (, n+))
factorial()

输出结果:
函数被执行了
factorial()调用耗时:0.000000s
3628800


正在回答

2 回答

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)

如果那个return r 是return f(*args,**kw)才会再调用一遍原函数


0 回复 有任何疑惑可以回复我~
time
performance(fun):
    timeadd(*args,**kw):
        t=time.time()
        r=fun(*args,**kw)
        tt=time.time()
        %(fun.,tt-t)
        r
    timeadd
factorial(n):
    (x,y: x*y, (, n+))
factorial()


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

举报

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

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

进入课程

根据执行顺序,执行装饰器的代码,再执行函数里面的代码,那是不是计算了两次阶乘?但是为什么根据log是执行了一次而已,只在装饰器里面调用的时候执行了

我要回答 关注问题
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号