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