1.Python中,一切皆對(duì)象,一個(gè)函數(shù)也可當(dāng)做一個(gè)對(duì)象傳遞,
2.裝飾器就是接受一個(gè)函數(shù)作為參數(shù),添加功能后返回一個(gè)新函數(shù)的函數(shù)或類。
3.python 中使用 @ 來(lái)使用裝飾器。
4.@ 只是裝飾器的語(yǔ)法糖,語(yǔ)法糖(Syntactic sugar),也譯為糖衣語(yǔ)法,是一個(gè)術(shù)語(yǔ),指計(jì)算機(jī)語(yǔ)言中添加的某種語(yǔ)法,這種語(yǔ)法對(duì)語(yǔ)言的功能并沒(méi)有影響,但是更方便程序員使用。通常來(lái)說(shuō)使用語(yǔ)法糖能夠增加程序的可讀性,從而減少程序代碼出錯(cuò)的機(jī)會(huì)。
使用裝飾器寫一個(gè)延時(shí)函數(shù)(裝飾器功能:計(jì)算函數(shù)運(yùn)行時(shí)間)
# _*_ coding:utf-8 _*_
import time
def log_time(func): # 接受一個(gè)函數(shù)作為參數(shù)
def _log(*args, **kwargs):
start_time = time.time()
res = func(*args, **kwargs)
print('use time:{}'.format(time.time() - start_time))
return res
return _log
@log_time # 使用裝飾器
def my_sleep():
time.sleep(2)
my_sleep()
""" @log_time 等價(jià)于:
log_time(my_sleep())
"""
使用類寫一個(gè)帶參數(shù)的裝飾器
class MyLog(object):
def __init__(self, on_off='on'): # 定義默認(rèn)參數(shù)
self.on_off = on_off
def __call__(self, func):
def _log(*args, **kwargs):
if self.on_off == 'on':
start = time.time()
res = func(*args, **kwargs)
end = time.time()
print('|運(yùn)行時(shí)長(zhǎng):{:.4f}'.format(end - start))
return res
elif self.on_off == 'off':
pass
else:
print('log:on_off傳參不對(duì)')
return _log
# 測(cè)試裝飾器
class Test():
@MyLog()
def test(self):
time.sleep(1)
Test().test()