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

关于装饰器的调用。。。。

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)

g1=performance(factorial)
print g1(10)

我用之前的调用方法添加了一些代码结果是这样的:

call factorial() in 0.000000s
3628800
call factorial() in 0.000000s
call fn() in 0.000000s
3628800

如果只是用两种方法的一种调用方法的话结果都是一样的:

call factorial() in 0.000000s
3628800

那么下面这个输出是怎么来的呢?

call factorial() in 0.000000s

有没有大神知道是怎么回事啊?

正在回答

2 回答

由于factorial已经被装饰器包裹了一层,你再做g1=performance(factorial)相当于包了两层装饰器,即

g1=performance(performance(factorial))

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

最后一个代码复制错了,应该是这个:

call fn() in 0.000000s


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

举报

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

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

进入课程

关于装饰器的调用。。。。

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