真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Python中Decorator的作用是什么

本篇文章給大家分享的是有關Python中Decorator的作用是什么,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

公司主營業(yè)務:成都網(wǎng)站設計、成都做網(wǎng)站、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)公司是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)公司推出祿豐免費做網(wǎng)站回饋大家。

首先來看一個簡單的例子:

# -*- coding: utf-8 -*-  def log_cost_time(func):      def wrapped(*args, **kwargs):          import time          begin = time.time()          try:              return func(*args, **kwargs)          finally:              print 'func %s cost %s' % (func.__name__, time.time() - begin)      return wrapped     @log_cost_time  def complex_func(num):      ret = 0      for i in xrange(num):          ret += i * i      return ret  #complex_func = log_cost_time(complex_func)     if __name__ == '__main__':      print complex_func(100000)     code snippet 0

代碼中,函數(shù)log_cost_time就是一個裝飾器,其作用也很簡單,打印被裝飾函數(shù)運行時間。

裝飾器的語法如下:

@dec  def func():pass

本質(zhì)上等同于: func = dec(func)。

在上面的代碼(code snippet  0)中,把line12注釋掉,然后把line18的注釋去掉,是一樣的效果。另外staticmethod和classmethod是兩個我們經(jīng)常在代碼中用到的裝飾器,如果對pyc反編譯,得到的代碼一般也都是  func = staticmthod(func)這種模式。當然,@符號的形式更受歡迎些,至少可以少拼寫一次函數(shù)名。

裝飾器是可以嵌套的,如

@dec0  @dec1  def func():pass

等將于 func = dec0(dec1(fun))。

裝飾器也有“副作用“”,對于被log_cost_time裝飾的complex_calc,  我們查看一下complex_func.__name__,輸出是:”wrapped“”。額,這個是log_cost_time里面inner  function(wrapped)的名字,調(diào)用者當然希望輸出是”complex_func”,為了解決這個問題,python提供了兩個函數(shù)。

  • functools.update_wrapper

原型: functools.update_wrapper(wrapper, wrapped[, assigned][, updated])

第三個參數(shù),將wrapped的值直接復制給wrapper,默認為(__doc__, __name__, __module__)

第四個參數(shù),update,默認為(__dict__)

  • unctools.wraps: update_wrapper的封裝

This is a convenience function for invoking  partial(update_wrapper,wrapped=wrapped,assigned=assigned,updated=updated) as a  function decorator when defining a wrapper function.

簡單改改代碼:

import functools  def log_cost_time(func):      @functools.wraps(func)      def wrapped(*args, **kwargs):          import time          begin = time.time()          try:              return func(*args, **kwargs)          finally:              print 'func %s cost %s' % (func.__name__, time.time() - begin)      return wrapped

再查看complex_func.__name__ 輸出就是 “complex_func”

裝飾器也是可以帶參數(shù)的。我們將上面的代碼略微修改一下:

def log_cost_time(stream):      def inner_dec(func):          def wrapped(*args, **kwargs):              import time              begin = time.time()              try:                  return func(*args, **kwargs)              finally:                  stream.write('func %s cost %s \n' % (func.__name__, time.time() - begin))          return wrapped      return inner_dec     import sys  @log_cost_time(sys.stdout)  def complex_func(num):      ret = 0      for i in xrange(num):          ret += i * i      return ret     if __name__ == '__main__':      print complex_func(100000)     code snippet 1

log_cost_time函數(shù)也接受一個參數(shù),該參數(shù)用來指定信息的輸出流,對于帶參數(shù)的decorator

@dec(dec_args)  def func(*args, **kwargs):pass

等價于 func = dec(dec_args)(*args, **kwargs)。

裝飾器對類的修飾也是很簡單的,只不過平時用得不是很多。舉個例子,我們需要給修改類的__str__方法,代碼很簡單。

def Haha(clz):      clz.__str__ = lambda s: "Haha"      return clz     @Haha  class Widget(object):      ''' class Widget '''     if __name__ == '__main__':      w = Widget()      print w

那什么場景下有必要使用decorator呢,設計模式中有一個模式也叫裝飾器。我們先簡單回顧一下設計模式中的裝飾器模式,簡單的一句話概述

動態(tài)地為某個對象增加額外的責任

由于裝飾器模式僅從外部改變組件,因此組件無需對它的裝飾有任何了解;也就是說,這些裝飾對該組件是透明的。

下圖來自《設計模式Java手冊》或者GOF的《設計模式》

Python中Decorator的作用是什么

回到Python中來,用decorator語法實現(xiàn)裝飾器模式是很自然的,比如文中的示例代碼,在不改變被裝飾對象的同時增加了記錄函數(shù)執(zhí)行時間的額外功能。當然,由于Python語言的靈活性,decorator是可以修改被裝飾的對象的(比如裝飾類的例子)。decorator在python中用途非常廣泛,下面列舉幾個方面:

(1)修改被裝飾對象的屬性或者行為

(2)處理被函數(shù)對象執(zhí)行的上下文,比如設置環(huán)境變量,加log之類

(3)處理重復的邏輯,比如有N個函數(shù)都可能跑出異常,但是我們不關心這些異常,只要不向調(diào)用者傳遞異常就行了,這個時候可以寫一個catchall的decorator,作用于所用可能跑出異常的函數(shù)

def catchall(func):      @functools.wraps(func)      def wrapped(*args, **kwargs):          try:              return func(*args, **kwargs)          except:              pass      return wrapped

以上就是Python中Decorator的作用是什么,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


網(wǎng)站標題:Python中Decorator的作用是什么
轉(zhuǎn)載注明:http://weahome.cn/article/jsddhj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部