關(guān)于Python中的內(nèi)存釋放問題
首先就不得不提到Python解釋器在何種情況下會釋放變量的內(nèi)存。Python引用了內(nèi)存計(jì)數(shù)這一簡單的計(jì)數(shù)來控制。
下面是引用計(jì)數(shù)的知識:
1)增加引用計(jì)數(shù)當(dāng)對象被創(chuàng)建并(將其引用)賦值給變量時(shí),該對象的引用計(jì)數(shù)被設(shè)置為1。
對象的引用計(jì)數(shù)增加的情況:
對象被創(chuàng)建:x=3.14
另外的別名被創(chuàng)建:y=x
被作為參數(shù)傳遞給函數(shù)(新的本地引用):foobar(x)
成為容器對象的一個(gè)元素:myList=[123,x,'xyz']
2)減少引用計(jì)數(shù)對象的引用計(jì)數(shù)減少的情況:
一個(gè)本地引用離開了其作用范圍。如foobar()函數(shù)結(jié)束時(shí)
對象的別名被顯式銷毀:dely
對象的一個(gè)別名被賦值給其他對象:x=123
對象被從一個(gè)窗口對象中移除:myList.remove(x)
窗口對象本身被銷毀:delmyList
3)del語句Del語句會刪除對象的一個(gè)引用,它的語法如下:delobj[,obj2[,...objN]]
例如,在上例中執(zhí)行dely會產(chǎn)生兩個(gè)結(jié)果:
從現(xiàn)在的名稱空間中刪除y
x的引用計(jì)數(shù)減1
下面我們來試驗(yàn)一下
importsys
x=3.14
print("原始引用值:",sys.getrefcount(x))
y=x
print("被y引用后:",sys.getrefcount(x))
x=4.0
print("重新賦值后:",sys.getrefcount(x))
dely
print("刪除y引用后:",sys.getrefcount(x))
原始引用值:3
被y引用后:4
重新賦值后:3
刪除y引用后:3
當(dāng)一個(gè)變量的引用計(jì)數(shù)為0的時(shí)候,就會被解釋器回收。當(dāng)然在交互模式下,內(nèi)存不會馬上釋放,重新啟動解釋器就會釋放了。
以上內(nèi)容為大家介紹了python培訓(xùn)之如何釋放內(nèi)存,希望對大家有所幫助,如果想要了解更多Python相關(guān)知識,請關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。