函數的調用:
def test1():
print("--- in test1 func----")
#調用函數
test1()
#此是ret引用函數
ret = test1
print(id(ret))
print(id(test1))
#通過引用調用函數
ret()
運行結果:
--- in test1 func----
140212571149040
140212571149040
--- in test1 func----
Paste_Image.png
閉包: 在函數內部再定義一個函數,并且這個函數用到了外邊函數的變量,那么將這個函數以及用到的一些變量稱之為閉包
Paste_Image.png
#定義一個函數
def test(number):
def test_in(number_in):
print("in test_in 函數, number_in is %d"%number_in)
return number+number_in
#其實這里返回的就是閉包的結果
return test_in
#給test函數賦值,這個20就是給參數number
ret = test(20)
#注意這里的100其實給參數number_in
print(ret(100))
#注意這里的200其實給參數number_in
print(ret(200))
運行結果:
in test_in 函數, number_in is 100
120
in test_in 函數, number_in is 200
220
1.閉包似優化了變量,原來需要類對象完成的工作,閉包也可以完成
2.由于閉包引用了外部函數的局部變量,則外部函數的局部變量沒有及時釋放,消耗內存
看一個閉包的實際例子:
def line_conf(a, b):
def line(x):
return a*x + b
return line
line1 = line_conf(1, 1)
line2 = line_conf(4, 5)
print(line1(5))
print(line2(5))
這個例子中,函數line與變量a,b構成閉包。
在創建閉包的時候,我們通過line_conf的參數a,b說明了這兩個變量的取值,這樣,我們就確定了函數的最終形式(y = x + 1和y = 4x + 5)。
我們只需要變換參數a,b,就可以獲得不同的直線表達函數。
由此,我們可以看到,閉包也具有提高代碼可復用性的作用。
如果沒有閉包,我們需要每次創建直線函數的時候同時說明a,b,x。
這樣,我們就需要更多的參數傳遞,也減少了代碼的可移植性。