所以
Python Essential Reference,第4版.说:
a = {}
b = {}
a['b'] = b
b['a'] = a
del a
del b
创建内存泄漏,解释器需要循环检测算法来删除a和b.
但是,当我试图弄清楚引用计数的方式时,在我看来,最后,a和b的refcounts都归零,因此不需要循环检测算法.喜欢:
a = {}
b = {}
refcounts:a = 1,b = 1
a['b'] = b
b['a'] = a
refcounts:a = 2,b = 2
del a
refcounts:b [‘a’] = 1,b = 1
del b
refcounts:a = 0,b = 0
我对refcounts的理解有什么问题?
最佳答案 del a不会破坏变量a指向的对象,它只会从当前命名空间中删除变量a.在此之后,该词典继续存在(因为其他词典仍然引用它),因此仍然引用第二个词典b.同样,del b不会导致第一个dict的引用计数达到零,因为只要它处于活动状态,它就会引用第二个dict,因此也不能删除它,并使另一个dict保持活动状态.对不起,这听起来很混乱,我不太清楚怎么说这个.
最后,看起来像这样(笨重的盒子是物体,箭头是参考):
+----------+ +----------+
| dict 1 | | dict 2 |
| | <- | key 'a' |
| key 'b' | -> | |
+----------+ +----------+