日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

使用装饰器时带括号与不带括号的区别

發(fā)布時間:2024/4/13 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 使用装饰器时带括号与不带括号的区别 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

之前我們在一個用于統(tǒng)計函數(shù)調(diào)用消耗時間的裝飾器中寫了一個裝飾器,用于統(tǒng)計函數(shù)調(diào)用時間。代碼如下:

from time import time from time import sleepdef count_time():def tmp(func):def wrapped(*args, **kargs):begin_time = time()result = func(*args, **kargs)end_time = time()cost_time = end_time - begin_timeprint '%s called cost time : %s' %(func.__name__, cost_time)return resultreturn wrappedreturn tmp

對于該裝飾器,我們必須這樣使用:

@count_time() def test():sleep(0.5)if __name__ == '__main__':test()

這里注意,裝飾器后面加了括號。

如果我們不加括號:

@count_time def test():sleep(0.5)if __name__ == '__main__':test()

就會產(chǎn)生錯誤:

Traceback (most recent call last):File "16.py", line 16, in <module>@count_time TypeError: count_time() takes no arguments (1 given)

?

但是很多裝飾器使用時,是不必加括號的,那么這是怎么回事?

?

我們將上面的裝飾器進行改寫:

from time import time from time import sleep import sysdef count_time(func):def wrapped(*args, **kargs):begin_time = time()result = func(*args, **kargs)end_time = time()cost_time = end_time - begin_timeprint '%s called cost time : %s ms' %(func.__name__, float(cost_time)*1000)return resultreturn wrapped

此時,就不需要加括號了。

這二者的區(qū)別在于,第一個存在括號,允許用戶傳入自定義信息,所以需要額外包裝一層,不加括號的版本則不需要。

?

所以當(dāng)我們需要自定義裝飾器內(nèi)的某些message時,就需要采用加括號的方式。

對于這個統(tǒng)計時間的裝飾器,我們可以這樣自定義信息:

#coding: utf-8 from time import time from time import sleepdef count_time(msg):def tmp(func):def wrapped(*args, **kargs):begin_time = time()result = func(*args, **kargs)end_time = time()cost_time = end_time - begin_timeprint 'msg: %s ,%s called cost time : %s' %(msg, func.__name__, cost_time)return resultreturn wrappedreturn tmp

然后這樣使用:

@count_time("foobar") def test():sleep(0.5)@count_time("測試消息") def test2():sleep(0.7)if __name__ == '__main__':test()test2()

結(jié)果如下:

msg: foobar ,test called cost time : 0.501540899277 msg: 測試消息 ,test2 called cost time : 0.701622009277

?

后面綜合前面幾篇,寫一個完整的裝飾器教程。

轉(zhuǎn)載于:https://www.cnblogs.com/inevermore/p/4219882.html

總結(jié)

以上是生活随笔為你收集整理的使用装饰器时带括号与不带括号的区别的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。