Python入门笔记之闭包
生活随笔
收集整理的這篇文章主要介紹了
Python入门笔记之闭包
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
2019獨角獸企業重金招聘Python工程師標準>>>
我們先來看一段代碼:
def sum_test(lst):def lazy_sum():return sum(lst)return lazy_sum這時你會發現?發現沒法把?lazy_sum?移到 sum_test 的外部,因為它引用了 sum_test 的參數?lst。像這種內層函數引用了外層函數的變量(參數也算變量),然后返回內層函數的情況,稱為閉包(Closure)。
閉包的特點是返回的函數還引用了外層函數的局部變量,所以,要正確使用閉包,就要確保引用的局部變量在函數返回后不能變。以下的這段代碼則不符合閉包的特點:
def count():fs = []for i in range(1, 4):def f():return i*ifs.append(f)return fs f1,f2,f3 = count() print f1(),f2(),f3() #輸出值為:9 9 9輸出值為9 9 9,而不是1 4 9,這是因為在count()只是返回了三個f()的函數,并沒有執行f()內的代碼,直到走到f1(),f2(),f3()時,才執行了f()內的代碼,而這個時候i的值已經變成了3,所以三個i*i的結果都將是9。這就不符合閉包的確保引用的局部變量在函數返回后不能變的特點。應該改為以下的代碼:
def count():fs = []for i in range(1, 4):def f(j):def h():return j*jreturn hr = f(i)fs.append(r)return fs f1, f2, f3= count() print f1(),f2(),f3() #輸出值為:1 4 9這時調用count()返回的三個函數時,返回的函數內的j*j中的j則不是一個會跟著for循環而變的變量了。這就是一個閉包了。
轉載于:https://my.oschina.net/lonelycode/blog/715722
總結
以上是生活随笔為你收集整理的Python入门笔记之闭包的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: webpack开发配置
- 下一篇: python-dev 安装错误