亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

無懼面試,帶你搞懂python 裝飾器

瀏覽:79日期:2022-07-13 16:12:49

寫在之前

「裝飾器」作為 Python 高級語言特性中的重要部分,是修改函數的一種超級便捷的方式,適當使用能夠有效提高代碼的可讀性和可維護性,非常的便利靈活。

「裝飾器」本質上就是一個函數,這個函數的特點是可以接受其它的函數當作它的參數,并將其替換成一個新的函數(即返回給另一個函數)。

可能現在這么看的話有點懵,為了深入理解「裝飾器」的原理,我們首先先要搞明白「什么是函數對象」,「什么是嵌套函數」,「什么是閉包」。關于這三個問題我在很久以前的文章中已經寫過了,你只需要點擊下面的鏈接去看就好了,這也是面試中常問的知識哦:

https://www.jb51.net/article/158738.htm

裝飾器

搞明白上面的三個問題,其實簡單點來說就是告訴你:函數可以賦值給變量,函數可嵌套,函數對象可以作為另一個函數的參數。

首先我們來看一個例子,在這個例子中我們用到了前面列出來的所有知識:

def first(fun): def second(): print(’start’) fun() print(’end’) print fun.__name__ return seconddef man(): print(’i am a man()’)f = first(man)f()

上述代碼的執行結果如下所示:

starti am a man()endman

上面的程序中,這個就是 first 函數接收了 man 函數作為參數,并將 man 函數以一個新的函數進行替換。看到這你有沒有發現,這個和我在文章剛開始時所說的「裝飾器」的描述是一樣的。既然這樣的話,那我們就把上述的代碼改造成符合 Python 裝飾器的定義和用法的樣子,具體如下所示:

def first(func): def second(): print(’start’) func() print(’end’) print (func.__name__) return second@firstdef man(): print(’i am a man()’)man()

上面這段代碼和之前的代碼的作用一模一樣。區別在于之前的代碼直接“明目張膽”的使用 first 函數去封裝 man 函數,而上面這個是用了「語法糖」來封裝 man 函數。至于什么是語法糖,不用細去追究,你就知道是類似「@first」這種形式的東西就好了。

在上述代碼中「@frist」在 man 函數的上面,表示對 man 函數使用 first 裝飾器。「@」 是裝飾器的語法,「first」是裝飾器的名稱。

下面我們再來看一個復雜點的例子,用這個例子我們來更好的理解一下「裝飾器」的使用以及它作為 Python 語言高級特性被人津津樂道的部分:

def check_admin(username): if username != ’admin’: raise Exception(’This user do not have permission’)class Stack: def __init__(self): self.item = [] def push(self,username,item): check_admin(username=username) self.item.append(item) def pop(self,username): check_admin(username=username) if not self.item: raise Exception(’NO elem in stack’) return self.item.pop()

上述實現了一個特殊的棧,特殊在多了檢查當前用戶是否為 admin 這步判斷,如果當前用戶不是 admin,則拋出異常。上面的代碼中將檢查當前用戶的身份寫成了一個獨立的函數 check_admin,在 push 和 pop 中只需要調用這個函數即可。這種方式增強了代碼的可讀性,減少了代碼冗余,希望大家在編程的時候可以具有這種意識。

下面我們來看看上述代碼用裝飾器來寫成的效果:

def check_admin(func): def wrapper(*args, **kwargs): if kwargs.get(’username’) != ’admin’: raise Exception(’This user do not have permission’) return func(*args, **kwargs) return wrapperclass Stack: def __init__(self): self.item = [] @check_admin def push(self,username,item): self.item.append(item) @check_admin def pop(self,username): if not self.item: raise Exception(’NO elem in stack’) return self.item.pop()

對比一下使用「裝飾器」和不使用裝飾器的兩種寫法,乍一看,好像使用「裝飾器」以后代碼的行數更多了,但是你有沒有發現代碼看起來好像更容易理解了一些。在沒有裝飾器的時候,我們先看到的是 check_admin 這個函數,我們得先去想這個函數是干嘛的,然后看到的才是對棧的操作;而使用裝飾器的時候,我們上來看到的就是對棧的操作語句,至于 check_admin 完全不會干擾到我們對當前函數的理解,所以使用了裝飾器可讀性更好了一些。

就和我在之前的文章中所講的「生成器」那樣,雖然 Python 的高級語言特性好用,但也不能亂用。裝飾器的語法復雜,通過我們在上面縮寫的裝飾器就可以看出,它寫完以后是很難調試的,并且使用「裝飾器」的程序的速度會比不使用裝飾器的程序更慢,所以還是要具體場景具體看待。

以上就是無懼面試,帶你搞懂python 裝飾器的詳細內容,更多關于python 裝飾器的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
主站蜘蛛池模板: 波多野吉衣一区二区三区四区 | 日本精品久久久久中文字幕8 | 亚洲一级毛片在线播放 | 欧美在线视频一区二区三区 | 亚洲综合色丁香麻豆 | 精品日韩在线视频 | 国产成人综合95精品视频免费 | 黄污在线观看 | 久久综合色区 | 打电话系列国产在线 | 激情欧美一区二区三区 | 亚洲久久久久 | 成年视频xxxxx免费播放软件 | 91老女人| 1024在线观看免费播放 | 欧美一级毛片一级 | 国产成人精品久久二区二区 | xzl仙踪林一区 | 欧美人牲| 国产午夜视频 | 国产在线一区二区 | 亚洲福利在线观看 | 欧美第一页草草影院 | 久久久久一区二区三区 | 99re7在线精品免费视频 | 视频一区免费 | 中国性视频 | 中国xxx片| 看日本真人一一级特黄毛片 | 日韩免费一区 | 超级碰碰碰碰97久久久久 | 欧美色视频免费高清播放 | 日本a级特黄特黄刺激大片 日本a黄 | 视频二区在线 | 大学生gayxxxx chinese | 日韩精品一区二三区中文 | 日韩视频二区 | 久久久久久99精品 | 欧美日韩一区二区三区四区 | 国产成人91青青草原精品 | 亚洲国产亚洲片在线观看播放 |