轉自:https://blog.csdn.net/windscloud/article/details/79732014
python中的del用法比較特殊,新手學習往往產生誤解,弄清del的用法,可以幫助深入理解python的內存方面的問題。
python的del不同於C的free和C++的delete。
由於python都是引用,而python有GC(垃圾自動回收)機制,所以,del語句作用在變量上,而不是數據對象上。
if __name__ == '__main__': a = 1 # 對象1被變量a引用,對象1的引用計數器為1 b = a # 對象1被變量b引用,對象1的引用計數器加1 c = a # 對象1被變量c引用,對象1的引用計數器加1 del a # 刪除變量a,解除a對對象1的引用,對象1的引用計數器減1 del b # 刪除變量b,解除b對對象1的引用,對象1的引用計數器減1 print(c) # 對象1仍被變量c引用,此時對象1的引用計數器為1 # del刪除的是變量,而不是數據 # 僅當某對象的引用計數器為0時,該對象才會被從內存中釋放
1 if __name__ == '__main__': 2 a = [1, 2, 3, 4, 5, 6] # 列表本身不包含數據1,2,3,...,6,而是包含變量a[0],a[1], ...,a[5] 3 b = a[0] # 拷貝列表元素,此處復制的不是數據對象1,而是為數據對象1創建新的變量引用,數據對象1的引用計數器加1 4 del a[0] # 解除變量a[0]對數據對象1的引用,對象1的引用計數器減1 5 print(a) # 輸出[2, 3, 4, 5, 6] 6 print(b) # 變量b引用的數據對象為1,輸出1