1、 內部函數 ,顧名思義,是函數內部定義的函數,其作用是封裝邏輯,使函數邏輯更為清晰。
def outer():
inner():
業務邏輯
return inner
2、 為何return inner而不是return inner()呢?
初學者可能都有此一問,我們知道,運行一個函數就是:func(),然后func會得出結果。同理,如果return inner()就是要返回inner()的運算結果,但是innner()函數沒有返回值,此時return inner()只能得到None。而retrun inner是返回inner這個函數,并不會運行這個函數。
總結:
return innner返回函數邏輯代碼,不運行函數
return inner()運行inner函數,將函數結果返回
3、 裝飾器
裝飾器用到的就是內部函數。如下,若把需要裝飾的函數稱之為目標函數,定義裝飾器decorator,把目標函數作為參數傳給decorator函數,然后定義內部函數wrapper,wapper用于包裝目標函數,包裝完畢后將wrappper函數返回。
由此,可以看出,decorator函數只是返回wrapper的邏輯代碼,并不會運行wrapper
def decorator(func):
def wrapper():
print('start')
func()
print('end')
return wrapper()
@decorator
def myfunc():
print('run')
myfunc()
上述代碼就是將myfunc函數作為參數傳遞給decorator函數,然后decorator函數中的內部函數wrapper函數調用了myfunc函數,并對其進行了簡單包裝,最后直接把wrapper中的邏輯返回。
運行結果:
若需要加參數,如下:
def log(text):
def deco(func):
def wrapper(*args,**kw):
print text
func(*args,**kw)
print text + " again"
return wrapper
return deco
@log("hello")
def myfun(message):
print message
myfun("world")
# 運行結果
# hello
# world
# hello again
4、 閉包
上面的wrapper函數就是閉包,閉包就是內部函數的一種。
具體可參考https://www.cnblogs.com/Lin-Yi/p/7305364.html
5、 Nonetype報錯
初學者在利用裝飾器時,可能會碰上這個報錯,何也?
其實是因為裝飾器返回不當,裝飾器本來應該返回一個函數,但是卻沒有返回,會引發此錯誤。檢查代碼,看看是否return語句嵌套不當,即可解決。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
