输入:
import time
def foo():
time.sleep(2)
print('foo...')

def bar():
time.sleep(3)
print('bar...')

def deco(f):
def inner():
start = time.time() #增加开始时间戳
f()
end = time.time() #增加结束时间戳
print('spend %s'%(end - start)) #添加功能为“打印函数执行时间”,所以要结束时间减去开始时间
return inner

foo = deco(foo) #给foo重新赋值,值为deco函数的返回值inner的内存地址
foo() #此时调用foo,相当于调用inner。另外inner里的f为闭包,是从deco传入的形参,实参为开始定义的函数foo
bar = deco(bar) #给bar重新赋值,值为deco函数的返回值inner的内存地址
bar() #此时调用bar,相当于调用inner。另外inner里的f为闭包,是从deco传入的形参,实参为开始定义的函数bar
输出:

foo...
spend 2.000398635864258
bar...
spend 3.0060887336730957

#########################################华丽的分割线####################################

输入:
import time
def deco(f):    #将装修器函数放到被装饰的函数前面
def inner():
start = time.time() #增加开始时间戳
f()
end = time.time() #增加结束时间戳
print('spend %s'%(end - start)) #添加功能为“打印函数执行时间”,所以要结束时间减去开始时间
return inner
@deco    #相当于foo = deco(foo)
def foo():
time.sleep(2)
print('foo...')

@deco #相当于bar = deco(bar)
def bar():
time.sleep(3)
print('bar...')

foo()
bar()

输出:

foo...
spend 2.0011203289031982
bar...
spend 3.0005199909210205

posted on 2021-12-04 15:50  csy113  阅读(29)  评论(0)    收藏  举报