关于装饰器的调用。。。。
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
有没有大神知道是怎么回事啊?