您好,登錄后才能下訂單哦!
裝飾器
裝飾器可以疊加使用,執(zhí)行是從下到上執(zhí)行的
無參裝飾器 @logger
1.它是一個語法糖
2.函數(shù)作為它 的形參
3.返回值也是一個函數(shù)
4.可以使用 @function 方式,簡化調(diào)用
注意: 此處的裝飾器的定義并不準(zhǔn)確,只是方便理解
裝飾器和高階函數(shù)
裝飾器是高階函數(shù),但裝飾器是對傳入函數(shù)功能的裝飾
裝飾器函數(shù)的演化過程:
"""
裝飾器
一個普通的加法函數(shù),想增強(qiáng)他的功能
"""
def add(x,y):
return x + y
"""增加信息輸出功能"""
def add(x,y):
print("call add,x+y")# 日志輸出到控制臺
return x + y
"""上面的函數(shù)是完成了需求,但是有缺點
1.print語句的耦合度太高
2.加法函數(shù)屬于業(yè)務(wù)功能,而輸出信息的功能,屬于非業(yè)務(wù)功能代碼,不該放在業(yè)務(wù)函數(shù)加法中"""
"""把添加功能移出來"""
def logger(fn):
print("call add,x+y")
ret = fn(3,4)
return ret
print(logger(add))
def logger(fn,x,y):
print("call add,x+y")
ret = fn(x,y)
return ret
print(logger(add,3,4))
def logger(fn,*args,**arges):
print("call add,x+y")
ret = fn(*args,**arges)
return ret
print(logger(add,3,4))
def logger(fn):
def wrapper(*args,**arges): # 可變位置傳參,可變關(guān)鍵字傳參
print("call add,x+y")
ret = fn(*args,**arges) # 參數(shù)解構(gòu)
return ret
return wrapper
print(logger(add)(4,5))
add = logger(add) # add = wrapper
ret = add(4,5) # wrapper(4,5)
裝飾器 核心思想
import datetime
def logger(fn):
def wrapper(*args,**arges): # 可變位置傳參,可變關(guān)鍵字傳參
print("前面增強(qiáng)")
start = datetime.datetime.now()
ret = fn(*args,**arges) # 參數(shù)解構(gòu)
delta = (datetime.datetime.now() - start).total_seconds()
print("so fast") if delta < 5 else print("so slow")
print("后面增強(qiáng)")
return ret
return wrapper
@logger # add = logger(add) => add 就是 wrapper
def add(x,y): # wrapper(4,5)
return x + y
ret = add(4,5) # wrapper(4,5) => logger(add)(4,5)
print(ret)
理解裝飾器:
1.裝飾器函數(shù)
2.前置功能增強(qiáng)
3.被增強(qiáng)函數(shù)
4.后置功能增強(qiáng)
def logger(fn): # 調(diào)用 被裝飾的函數(shù)
def wrapper(*args,**kwargs): # 傳入被裝飾函數(shù)參數(shù)
print("before function") # 前置功能增強(qiáng)
ret = fn(*args,**kwargs) # 使用被裝飾函數(shù)的功能
print("after function") # 后置功能增強(qiáng)
return ret # 返回被裝飾函數(shù)的 計算結(jié)果
return wrapper # 返回 被裝飾的函數(shù)
@logger # 無參裝飾器
# @logger <==> add = logger(add) = wrapper # add(x,y) == wrapper(x,y)
def add(x,y): # 被裝飾的函數(shù)
return x + y
add(3,4)
print(add(3,4))
#看似調(diào)用add函數(shù),使用了裝飾器@logger之后,實際上 調(diào)用的是 wraaper(*args,**kwargs)函數(shù)
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。