Python裝飾器的執(zhí)行過(guò)程實(shí)例分析
本文實(shí)例分析了Python裝飾器的執(zhí)行過(guò)程。分享給大家供大家參考,具體如下:
今天看到一句話:裝飾器其實(shí)就是對(duì)閉包的使用,仔細(xì)想想,其實(shí)就是這回事,今天又看了下閉包,基本上算是弄明白了閉包的執(zhí)行過(guò)程了。其實(shí)加上幾句話以后就可以很容易的發(fā)現(xiàn),思路給讀者,最好自己總結(jié)一下,有助于理解。通過(guò)代碼來(lái)說(shuō)吧。
第一種,裝飾器本身不傳參數(shù),相對(duì)來(lái)說(shuō)過(guò)程相對(duì)簡(jiǎn)單的
#!/usr/bin/python
#coding: utf-8
# 裝飾器其實(shí)就是對(duì)閉包的使用
def dec(fun):
print("call dec")
def in_dec():
print("call in_dec")
fun()
# 必須加上返回語(yǔ)句,不然的話會(huì)默認(rèn)返回None
return in_dec
@dec
def fun():
print("call fun")
# 注意上面的返回語(yǔ)句加上還有不加上的時(shí)候這一句執(zhí)行的區(qū)別
print(type(fun))
fun()
'''
通過(guò)觀察輸出結(jié)果可以知道函數(shù)執(zhí)行的過(guò)程
call dec
<type 'function'>
call in_dec
call fun
觀察這幾組數(shù)據(jù)以后,其實(shí)很容易發(fā)現(xiàn),先執(zhí)行裝飾器,執(zhí)行過(guò)裝飾器以后,代碼繼續(xù)執(zhí)行最后的print和fun()語(yǔ)句,
但是此時(shí)的fun函數(shù)其實(shí)是指向in_dec的,并不是@下面的fun函數(shù),所以接下來(lái)執(zhí)行的是in_dec,在in_dec中有一個(gè)fun()語(yǔ)句,
遇到這個(gè)以后才是執(zhí)行@后面的fun()函數(shù)的。
'''
第二種,裝飾器本身傳參數(shù),個(gè)人認(rèn)為相對(duì)復(fù)雜,這個(gè)過(guò)程最好自己總結(jié),有問(wèn)題大家一塊探討
#!/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))
'''接下來(lái)的是輸出結(jié)果,通過(guò)結(jié)果其實(shí)很容易發(fā)現(xiàn)執(zhí)行的過(guò)程
call performance
call log_decrator 通過(guò)觀察前兩組的輸出結(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入門(mén)與進(jìn)階經(jīng)典教程》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
python常用request庫(kù)與lxml庫(kù)操作方法整理總結(jié)
一路學(xué)習(xí),一路總結(jié),技術(shù)就是這樣,應(yīng)用之后,在進(jìn)行整理,才可以加深印象。本篇文字為小節(jié)篇,核心總結(jié) requests 庫(kù)與 lxml 庫(kù)常用的操作2021-08-08
利用Python批量循環(huán)讀取Excel的技巧分享
這篇文章主要為大家詳細(xì)介紹了何用Python批量循環(huán)讀取Excel,文中的示例代碼講解詳細(xì),對(duì)我們的學(xué)習(xí)或工作有一定的幫助,感興趣的可以了解一下2023-07-07
Python Websocket服務(wù)端通信的使用示例
這篇文章主要介紹了Python Websocket服務(wù)端通信的使用示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
Python實(shí)現(xiàn)將Word和Excel文件轉(zhuǎn)換為PPT
在日常工作中,我們經(jīng)常需要將多個(gè)Word文檔或Excel表格的內(nèi)容匯總到一個(gè)PPT演示文稿中,手動(dòng)執(zhí)行這項(xiàng)任務(wù)可能非常耗時(shí),因此,使用Python自動(dòng)化這個(gè)過(guò)程可以大大提高效率,所以本文給大家介紹了Python實(shí)現(xiàn)將Word和Excel文件轉(zhuǎn)換為PPT,需要的朋友可以參考下2024-08-08

