Python中裝飾器的執(zhí)行過(guò)程有哪些-創(chuàng)新互聯(lián)

本篇文章為大家展示了Python中裝飾器的執(zhí)行過(guò)程有哪些,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、微信小程序開(kāi)發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了普安免費(fèi)建站歡迎大家使用!

第一種,裝飾器本身不傳參數(shù),相對(duì)來(lái)說(shuō)過(guò)程相對(duì)簡(jiǎn)單的

#!/usr/bin/python
#coding: utf-8
# 裝飾器其實(shí)就是對(duì)閉包的使用
def dec(fun):
  print("call dec")
  def in_dec():
    print("call in_dec")
    fun()
  # 必須加上返回語(yǔ)句,不然的話會(huì)默認(rèn)返回None
  return in_dec
@dec
def fun():
  print("call fun")
# 注意上面的返回語(yǔ)句加上還有不加上的時(shí)候這一句執(zhí)行的區(qū)別
print(type(fun))
fun()
'''
通過(guò)觀察輸出結(jié)果可以知道函數(shù)執(zhí)行的過(guò)程
call dec
<type 'function'>
call in_dec
call fun
觀察這幾組數(shù)據(jù)以后,其實(shí)很容易發(fā)現(xiàn),先執(zhí)行裝飾器,執(zhí)行過(guò)裝飾器以后,代碼繼續(xù)執(zhí)行最后的print和fun()語(yǔ)句,
但是此時(shí)的fun函數(shù)其實(shí)是指向in_dec的,并不是@下面的fun函數(shù),所以接下來(lái)執(zhí)行的是in_dec,在in_dec中有一個(gè)fun()語(yǔ)句,
遇到這個(gè)以后才是執(zhí)行@后面的fun()函數(shù)的。
'''

第二種,裝飾器本身傳參數(shù),個(gè)人認(rèn)為相對(duì)復(fù)雜,這個(gè)過(guò)程最好自己總結(jié),有問(wèn)題大家一塊探討

#!/usr/bin/python
#coding: utf-8
import time, functools
def performance(unit):
  print("call performance")
  def log_decrator(f):
    print("call log_decrator")
    @functools.wraps(f)
    def wrapper(*arg, **kw):
      print("call wrapper")
      t1 = time.time()
      t = f(*arg, **kw)
      t2 = time.time()
      tt = (t2 - t1) * 1000 if unit == "ms" else (t2 - t1)
      print 'call %s() in %f %s' % (f.__name__, tt, unit)
      return t
    return wrapper
  return log_decrator
@performance("ms")
def factorial(n):
  print("call factorial")
  return reduce(lambda x, y: x * y, range(1, 1 + n))
print(type(factorial))
#print(factorial.__name__)
print(factorial(10))
'''接下來(lái)的是輸出結(jié)果,通過(guò)結(jié)果其實(shí)很容易發(fā)現(xiàn)執(zhí)行的過(guò)程
call performance
call log_decrator 通過(guò)觀察前兩組的輸出結(jié)果可以知道,先執(zhí)行裝飾器
<type 'function'>
call wrapper
call factorial
call factorial() in 0.000000 ms
3628800
'''

上述內(nèi)容就是Python中裝飾器的執(zhí)行過(guò)程有哪些,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

新聞名稱:Python中裝飾器的執(zhí)行過(guò)程有哪些-創(chuàng)新互聯(lián)
當(dāng)前鏈接:http://www.muchs.cn/article48/depiep.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)全網(wǎng)營(yíng)銷推廣、網(wǎng)站建設(shè)、虛擬主機(jī)品牌網(wǎng)站制作、網(wǎng)站設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁(yè)設(shè)計(jì)