Python裝飾器的執(zhí)行過程實(shí)例分析
本文實(shí)例分析了Python裝飾器的執(zhí)行過程。分享給大家供大家參考,具體如下:
今天看到一句話:裝飾器其實(shí)就是對(duì)閉包的使用,仔細(xì)想想,其實(shí)就是這回事,今天又看了下閉包,基本上算是弄明白了閉包的執(zhí)行過程了。其實(shí)加上幾句話以后就可以很容易的發(fā)現(xiàn),思路給讀者,最好自己總結(jié)一下,有助于理解。通過代碼來說吧。
第一種,裝飾器本身不傳參數(shù),相對(duì)來說過程相對(duì)簡單的
#!/usr/bin/python #coding: utf-8 # 裝飾器其實(shí)就是對(duì)閉包的使用 def dec(fun): print("call dec") def in_dec(): print("call in_dec") fun() # 必須加上返回語句,不然的話會(huì)默認(rèn)返回None return in_dec @dec def fun(): print("call fun") # 注意上面的返回語句加上還有不加上的時(shí)候這一句執(zhí)行的區(qū)別 print(type(fun)) fun() ''' 通過觀察輸出結(jié)果可以知道函數(shù)執(zhí)行的過程 call dec <type 'function'> call in_dec call fun 觀察這幾組數(shù)據(jù)以后,其實(shí)很容易發(fā)現(xiàn),先執(zhí)行裝飾器,執(zhí)行過裝飾器以后,代碼繼續(xù)執(zhí)行最后的print和fun()語句, 但是此時(shí)的fun函數(shù)其實(shí)是指向in_dec的,并不是@下面的fun函數(shù),所以接下來執(zhí)行的是in_dec,在in_dec中有一個(gè)fun()語句, 遇到這個(gè)以后才是執(zhí)行@后面的fun()函數(shù)的。 '''
第二種,裝飾器本身傳參數(shù),個(gè)人認(rèn)為相對(duì)復(fù)雜,這個(gè)過程最好自己總結(jié),有問題大家一塊探討
#!/usr/bin/python #coding: utf-8 import time, functools def performance(unit): print("call performance") def log_decrator(f): print("call log_decrator") @functools.wraps(f) def wrapper(*arg, **kw): print("call wrapper") t1 = time.time() t = f(*arg, **kw) t2 = time.time() tt = (t2 - t1) * 1000 if unit == "ms" else (t2 - t1) print 'call %s() in %f %s' % (f.__name__, tt, unit) return t return wrapper return log_decrator @performance("ms") def factorial(n): print("call factorial") return reduce(lambda x, y: x * y, range(1, 1 + n)) print(type(factorial)) #print(factorial.__name__) print(factorial(10)) '''接下來的是輸出結(jié)果,通過結(jié)果其實(shí)很容易發(fā)現(xiàn)執(zhí)行的過程 call performance call log_decrator 通過觀察前兩組的輸出結(jié)果可以知道,先執(zhí)行裝飾器 <type 'function'> call wrapper call factorial call factorial() in 0.000000 ms 3628800 '''
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python加密解密算法與技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進(jìn)階經(jīng)典教程》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
Python Pandas數(shù)據(jù)分析工具用法實(shí)例
這篇文章主要介紹了Python Pandas數(shù)據(jù)分析工具用法實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11利用python、tensorflow、opencv、pyqt5實(shí)現(xiàn)人臉實(shí)時(shí)簽到系統(tǒng)
這篇文章主要介紹了利用python、tensorflow、opencv、pyqt5實(shí)現(xiàn)人臉實(shí)時(shí)簽到系統(tǒng),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09Python基礎(chǔ)之hashlib模塊subprocess模塊logging模塊
這篇文章主要為大家介紹了Python基礎(chǔ)之hashlib模塊subprocess模塊logging模塊示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11Python實(shí)現(xiàn)光速定位并提取兩個(gè)文件的不同之處
如果你經(jīng)常與Excel或Word打交道,那么從兩份表格/文檔中找到不一樣的元素是一件讓人很頭疼的工作。本文就將以兩份真實(shí)的Excel/Word文件為例,講解如何使用Python光速對(duì)比并提取文件中的不同之處2022-08-08Pytorch中如何調(diào)用forward()函數(shù)
這篇文章主要介紹了Pytorch中如何調(diào)用forward()函數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02