您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“python中裝飾器有哪些作用”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學習一下“python中裝飾器有哪些作用”這篇文章吧。
python裝飾器就是用于拓展原來函數(shù)功能的一種函數(shù),這個函數(shù)的特殊之處在于它的返回值也是一個函數(shù),使用python裝飾器的好處就是在不用更改原函數(shù)的代碼前提下給函數(shù)增加新的功能。
一般而言,我們要想拓展原來函數(shù)代碼,最直接的辦法就是侵入代碼里面修改,但是最簡單的方式并不是最安全最合適的方式,根據(jù)擴展開放修改封閉的原則,修改原函數(shù)代碼是不可取的.比如下面的有一個案例:
A公司有一個核心接口部門M提供核心業(yè)務(wù)接口,有三個業(yè)務(wù)部門(N,W,Z)需要調(diào)用核心業(yè)務(wù)接口,在正常運行了一年后,公司規(guī)范接口調(diào)用需要驗證用戶權(quán)限進行接口調(diào)用,現(xiàn)在需要實現(xiàn)這個擴展功能如何在花費最小成本完成?
樣例代碼如下:
############### 核心接口部門 ############### def f1(): print('f1') def f2(): print('f2') def f3(): print('f3') def f4(): print('f4') ############### 業(yè)務(wù)部門N 調(diào)用核心接口提供的功能 ############### f1() f2() f3() f4() ############### 業(yè)務(wù)部門W 調(diào)用核心接口提供的功能 ############### f1() f2() f3() f4() ############### 業(yè)務(wù)部門Z 調(diào)用核心接口提供的功能 ############### f1() f2() f3() f4()
############### 核心接口部門 ############### def verify(): print('驗證代碼') def f1(): verify() print('f1') def f2(): verify() print('f2') def f3(): verify() print('f3') def f4(): verify() print('f4')
分析:違反了開放封閉原則!對擴展是開放的,對修改封閉。對于核心的功能寫好之后是不應(yīng)許進入到功能里面去修改的。如果有1000個接口,你就得改一千次,雖然對于調(diào)用者無感,但核心接口部門成本很高。
############### 核心接口部門 ############### def verify(): print('驗證代碼') def f1(): print('f1') def f2(): print('f2') def f3(): print('f3') def f4(): print('f4') ############### 業(yè)務(wù)部門N 調(diào)用核心接口提供的功能 ############### if(verify()){ f1() f2() f3() f4() } else { print('未通過驗證') } ############### 業(yè)務(wù)部門W 調(diào)用核心接口提供的功能 ############### if(verify()){ f1() f2() f3() f4() } else { print('未通過驗證') } ############### 業(yè)務(wù)部門Z 調(diào)用核心接口提供的功能 ############### if(verify()){ f1() f2() f3() f4() } else { print('未通過驗證') }
分析:
上述代碼滿足開放封閉原則。核心接口部門也是只要擴展一個驗證功能即可,但業(yè)務(wù)調(diào)用部門需要進行驗證功能調(diào)用,這不利于調(diào)用者使用。
############### 核心接口部門 ############### def verify(func): def inner(): # 驗證1 # 驗證2 # 驗證3 return func() return inner @verify def f1(): print('f1') @verify def f2(): print('f2') @verify def f3(): print('f3') @verify def f4(): print('f4')
分析:
上述裝飾器解決驗證問題,只要核心接口部門進行操作,并且滿足開放封閉原則。下面以f1為例, 執(zhí)行verify函數(shù),并將 @verify 下面的 函數(shù) 作為verify函數(shù)的參數(shù),即:@verify 等價于verify(f1) 所以,內(nèi)部就會去執(zhí)行: def inner: #驗證 return f1() # func是參數(shù),此時 func 等于 f1 return inner # 返回的 inner,inner代表的是函數(shù),非執(zhí)行函數(shù) 其實就是將原來的 f1 函數(shù)塞進另外一個函數(shù)中 將執(zhí)行完的 verify 函數(shù)返回值賦值給@verify下面的函數(shù)的函數(shù)名 verify函數(shù)的返回值是: def inner: #驗證 return 原來f1() # 此處的 f1 表示原來的f1函數(shù) 然后,將此返回值再重新賦值給 f1,即: 新f1 = def inner: #驗證 return 原來f1() 所以,以后業(yè)務(wù)部門想要執(zhí)行 f1 函數(shù)時,就會執(zhí)行 新f1 函數(shù), 在 新f1 函數(shù)內(nèi)部先執(zhí)行驗證,再執(zhí)行原來的f1函數(shù),然后將 原來f1 函數(shù)的返回值 返回給了業(yè)務(wù)調(diào)用者。 如此一來, 即執(zhí)行了驗證的功能,又執(zhí)行了原來f1函數(shù)的內(nèi)容,并將原f1函數(shù)返回值 返回給業(yè)務(wù)調(diào)用著。
上面我們寫的是沒有帶參數(shù)的,我們?nèi)绾螌憥?shù)的呢?
def verify(func): def inner(arg1): # 驗證1 # 驗證2 # 驗證3 return func(arg1) return inner @verify def f1(arg1): print('f1')
備注:如果你要指定參數(shù)個數(shù),就添加指定個數(shù)參數(shù)到里面即可。如下:
def verify(func): def inner(arg1,arg2): # 驗證1 # 驗證2 # 驗證3 return func(arg1,arg2) return inner @verify def f1(arg1,arg2): print('f1')
def verify(func): def inner(*args,**kwargs): # 驗證1 # 驗證2 # 驗證3 return func(*args,**kwargs) return inner @verify def f1(arg1,arg2,arg3,arg4,arg5): print('f1')
def w1(func): def inner(*args,**kwargs): # 驗證1 # 驗證2 # 驗證3 return func(*args,**kwargs) return inner def w2(func): def inner(*args,**kwargs): # 驗證1 # 驗證2 # 驗證3 return func(*args,**kwargs) return inner @w1 @w2 def f1(arg1,arg2,arg3): print 'f1'
以上是“python中裝飾器有哪些作用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。