新聞中心
我們?cè)谏弦黄恼?Python實(shí)例來認(rèn)識(shí)并發(fā)與并行)中用到了 @timer ,在函數(shù)定義時(shí),加上一個(gè)小小的 @timer ,這樣,函數(shù)執(zhí)行結(jié)束后,就會(huì)自動(dòng)在控制臺(tái)匯報(bào)自己運(yùn)行的時(shí)間。

成都創(chuàng)新互聯(lián)公司長(zhǎng)期為近1000家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為寧縣企業(yè)提供專業(yè)的成都網(wǎng)站制作、成都網(wǎng)站建設(shè)、外貿(mào)營(yíng)銷網(wǎng)站建設(shè),寧縣網(wǎng)站改版等技術(shù)服務(wù)。擁有十年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
比如下面這樣:
- @timer
- def piper():
- for i in range(10000):
- i = i * i ** 10
- piper()
- 輸出:
- timer: using 0.00600 s
實(shí)際上,這個(gè)計(jì)時(shí)器邏輯 @timer 是我們自己用 Python 中的修飾器特性[1]來實(shí)現(xiàn)的。
拆解邏輯
其實(shí)我們不用修飾器,自己也能實(shí)現(xiàn)計(jì)時(shí)的邏輯。
- def piper():
- for i in range(10000):
- i = i * i ** 10
- t = time.time() # 記錄函數(shù)開始時(shí)時(shí)間
- piper()
- print(f"timer: using {time.time() - t :.5f} s") # 獲取函數(shù)運(yùn)行時(shí)間并打印
注意到我們執(zhí)行函數(shù)時(shí),在其上下都包裹上了邏輯。如果我們希望函數(shù)自帶計(jì)時(shí)邏輯,那么為了包住原函數(shù),只能去新定義一個(gè)函數(shù)。
- def time_wrapper(func):
- # func 是一個(gè)函數(shù)
- t = time.time()
- func()
- print(f"timer: using {time.time() - t :.5f} s")
- time_wrapper(piper)
- 輸出:
- timer: using 0.00600 s
我們想測(cè)試某一個(gè)函數(shù)運(yùn)行時(shí)間時(shí),將函數(shù)名輸入到 time_wrapper 里面就好。
更優(yōu)雅的改進(jìn)
上述代碼顯然有缺點(diǎn):
- 我們?cè)诰幊虝r(shí),心智負(fù)擔(dān)增大了;此外,代碼更冗長(zhǎng)了
- 如果我們只是希望函數(shù)新增一個(gè)功能,顯然用 time_wrapper 是不行的,因?yàn)槠洳]有改變 piper 本身
于是我們請(qǐng)出今天的主角 修飾器@wraps[2] 。
還用我們的 timer 舉例子,我們讓所有在 @timer 下的函數(shù),都經(jīng)過如下處理:
- def timer(func):
- @wraps(func)
- def inner_func():
- t = time.time()
- rts = func()
- print(f"timer: using {time.time() - t :.5f} s")
- return rts
- return inner_func
以 piper 為例,我們經(jīng)歷了如下變化。
- @timer
- def 原始piper():
- for i in range(10000):
- i = i * i ** 10
實(shí)際上,當(dāng)你再調(diào)用 piper 時(shí),你的 piper 內(nèi)部邏輯早已變?yōu)椋?/p>
- def 當(dāng)前piper():
- t = time.time()
- rts = 原始piper()
- print(f"timer: using {time.time() - t :.5f} s")
- return rts
總結(jié)
本文簡(jiǎn)單與讀者朋友們「科普」一下修飾器,注意到我們這里實(shí)際上僅僅修飾了無參數(shù)的函數(shù)。其實(shí),修飾器還有許多更加優(yōu)雅用途,比如傳入?yún)?shù) *args, **kwargs ,修飾類 __call__ 等用法。期待以后我遇到好的應(yīng)用場(chǎng)景,將經(jīng)驗(yàn)分享給朋友們。
網(wǎng)站題目:@wraps修飾器:讓你的Python代碼更加簡(jiǎn)短可愛|從簡(jiǎn)單實(shí)例來認(rèn)識(shí)它
分享路徑:http://m.5511xx.com/article/cdsiigj.html


咨詢
建站咨詢
