达伦·托马斯给出了一个很好的答案。然而,Java和Python方法之间的一个大区别是,在普通情况下(没有循环引用)使用引用计数时,对象会立即被清除,而不是在以后某个不确定的日期被清除。
例如,我可以用CPython编写草率的、不可移植的代码,比如def parse_some_attrs(fname):
return open(fname).read().split("~~~")[2:4]
我打开的那个文件的文件描述符将立即被清除,因为一旦对打开文件的引用消失,文件就会被垃圾收集,文件描述符就会被释放。当然,如果我运行Jython、IronPython或PyPy,那么垃圾收集器不一定要运行很久;可能我会先用完文件描述符,然后我的程序就会崩溃。
所以你应该写一些看起来像def parse_some_attrs(fname):
with open(fname) as f:
return f.read().split("~~~")[2:4]
但有时人们喜欢依赖引用计数来释放他们的资源,因为它有时会使代码更短。
我想说,最好的垃圾收集器是性能最好的垃圾收集器,目前看来是Java风格的世代垃圾收集器,它可以在单独的线程中运行,并有所有这些疯狂的优化等。您编写代码的方式的差异应该可以忽略,理想情况下是不存在的。