溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

python中裝飾器有哪些作用

發(fā)布時間:2021-10-18 15:32:07 來源:億速云 閱讀:173 作者:小新 欄目:編程語言

這篇文章主要為大家展示了“python中裝飾器有哪些作用”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學習一下“python中裝飾器有哪些作用”這篇文章吧。

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()

.核心接口部門重構(gòu)原函數(shù),添加驗證代碼

############### 核心接口部門 ###############
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)用者無感,但核心接口部門成本很高。

核心接口部門擴展驗證接口,業(yè)務(wù)部門調(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)用者使用。

核心接口裝飾器進行驗證,業(yè)務(wù)部門無感

############### 核心接口部門 ###############

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ù)的呢?

帶一個參數(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ù)到里面即可。如下:

帶兩個參數(shù)

def verify(func):
    def inner(arg1,arg2):
        # 驗證1
        # 驗證2
        # 驗證3
        return func(arg1,arg2)
    return inner

@verify
def f1(arg1,arg2):
    print('f1')

帶N個參數(shù)

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')

一個函數(shù)可以有多個裝飾器

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è)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(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)容。

AI