裝飾器的使用

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()
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容