python中閉包

2022-06-23 23:21:09 字數 1631 閱讀 6979

在函式內部定義的函式和外部定義的函式是一樣的,只是他們無法被外部訪問:

def

g():

print

'g()...

'def

f():

print

'f()...

'return g

將 g 的定義移入函式 f 內部,防止其他**呼叫 g:

def

f():

print

'f()...

'def

g():

print

'g()...

'return g

def

calc_sum(lst):

deflazy_sum():

return

sum(lst)

return lazy_sum

注意: 發現沒法把 lazy_sum 移到 calc_sum 的外部,因為它引用了 calc_sum 的引數 lst。

像這種內層函式引用了外層函式的變數(引數也算變數),然後返回內層函式的情況,稱為閉包(closure)

閉包的特點是返回的函式還引用了外層函式的區域性變數,所以,要正確使用閉包,就要確保引用的區域性變數在函式返回後不能變。舉例如下:

#

希望一次返回3個函式,分別計算1x1,2x2,3x3:

defcount():

fs =

for i in range(1, 4):

deff():

return i*i

return

fsf1, f2, f3 = count()

你可能認為呼叫f1(),f2()和f3()結果應該是1,4,9,但實際結果全部都是 9。

>>>f1()

9>>>f2()

9>>>f3()

9

原因就是當count()函式返回了3個函式時,這3個函式所引用的變數 i 的值已經變成了3。由於f1、f2、f3並沒有被呼叫,所以,此時他們並未計算 i*i,當 f1 被呼叫時:

>>>f1()

9 #

因為f1現在才計算i*i,但現在i的值已經變為3

因此,返回函式不要引用任何迴圈變數,或者後續會發生變化的變數。

練習:返回閉包不能引用迴圈變數,請改寫count()函式,讓它正確返回能計算1x1、2x2、3x3的函式。

def

count():

fs =

for i in range(1, 4):

#問題的產生是因為函式只在執行時才去獲取外層引數i,若函式定義時可以獲取到i,問題便可解決。

#而預設引數正好可以完成定義時獲取i值且執行函式時無需引數輸入的功能,

#所以在函式f()定義中改為f(m = i),函式f返回值改為m*m即可.

def f(m =i):

return m *m

return

fsf1, f2, f3 =count()

print f1(), f2(), f3()

結果:

1 4 9

python包中 init

1 init py定義包的屬性和方法 一般為空檔案,但是必須存在,沒有 init py表明他所在的目錄只是目錄不是包 2 匯入包的時候使用...

python中的閉包

1 定義 閉包是由函式及其相關的引用環境組合而成的實體 即 閉包 函式 引用環境 想想erlang的外層函式傳入一個引數a 內層函式依舊傳入一個引數b 內層函式使用a和b 最後返回內層函式 2 作用 由於閉包打包了內層函式和外部函式中的區域性變數,由於函式體在記憶體中均以例項的形式進行儲存,而當函式執行...

python 專案中包中 init

開發python專案時,我遇到了一個這樣的現象,當我新建一個pythonpackage時,總會自動地生成一個空的 init py檔案,因為是...