亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

不太理解這個裝飾器的運行過程

import time

def performance(unit):
??? def perf_decorator(f):
??????? def wrapper(*args, **kw):
??????????? t1 = time.time()
??????????? r = f(*args, **kw)
??????????? t2 = time.time()
??????????? t = (t2 - t1) * 1000 if unit=='ms' else (t2 - t1)?????????????#
??????????? print 'call %s() in %f %s' % (f.__name__, t, unit)
??????????? return r
??????? return wrapper
??? return perf_decorator

@performance('ms')
def factorial(n):
??? return reduce(lambda x,y: x*y, range(1, n+1))

print factorial(10)

請問ms參數首先返回在哪里?是#處嗎?

如果是,接下來該執行哪一步?

正在回答

3 回答

當執行factorial(10)時,會先去執行注解,也就是@performance('ms')。因為帶參數,所以會先執行def performance(unit),把字符串ms傳到unit,然后會再把被注解的函數作為參數執行def perf_decorator(f),至此注解部分就已經執行完畢了。接下來就是執行函數def factorial(n),也就是def wrapper(*args, **kw),然后該計時的計時,在計時的過程中就會執行真正的函數f(*args, **kw),并在最后return返回值,也就是print打印出的東西,流程就是這樣。

但是當執行def factorial(n)即factorial(10)時,實際上執行的函數已經不是factorial函數了,被替換成了wrapper函數,可以在factorial函數內打印下函數名:

@performance('ms')
def?factorial(n):
????print?'function?name?is?%s'?%?factorial.__name__
????return?reduce(lambda?x,y:?x*y,?range(1,?n+1))

會發現打印出的是wrapper。在2-14中也有解釋

3 回復 有任何疑惑可以回復我~
#1

weixin_慕粉0189013 提問者

好的 謝謝
2019-08-05 回復 有任何疑惑可以回復我~

好的?謝謝

0 回復 有任何疑惑可以回復我~

裝飾器是對函數的一種包裝,通過一個高階函數包裝原函數,擴充其功能而不改變其原本代碼。調用peformance函數接收字符串‘ms’后完成了內部函數的定義并返回了函數對象perf_decorator。所以@performance('ms')其實是@perf_decorator。在調用factorial時,‘ms’參數才傳入#處

0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消
python進階
  • 參與學習       255563    人
  • 解答問題       3038    個

學習函數式、模塊和面向對象編程,掌握Python高級程序設計

進入課程

不太理解這個裝飾器的運行過程

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號