python - 覆盖对象实例不释放内存?

标签 python class garbage-collection circular-reference

我有一个 python 对象,它本质上是其他对象实例的集合。您可以将其他对象附加到它(它只是存储在列表中)。它是在读取文件时创建的,例如:

def file_reader(file):
    obj = MyCollection()

    for line in file:
        other_obj = line_reader(line)
        obj.append(other_obj)
    return obj

如果我稍后尝试覆盖对象(通过读取不同的文件),原始数据不会被删除,对象只是被扩展。奇怪的是,如果我使用不同的引用,这似乎会发生:

obj1 = file_reader(file)
obj2 = file_reader(file1)

我怀疑我在循环引用方面遇到了某种问题,但我不太明白其中的逻辑。 有人有想法吗?

编辑: MyCollection 的基本部分如下所示:

class MyCollection(object):

    def __init__(self, objs = []):
        self.objs = objs

   def append(self, obj):
        self.objs.append(obj)

最佳答案

我会假设你目前有这样的东西:

class MyCollection():
    listOfThings = []
    def __init__(self):

在这种情况下,listOfThings 是一个类属性,它在MyCollection 类的所有实例之间共享。相反,您需要一个实例属性,为每个实例分开:

class MyCollection():
    def __init__(self):
        self.listOfThings = []

编辑:太接近了!

您遇到的问题是:

def __init__(self, objs = []):

在这里,objs 被称为“可变默认参数”。默认参数值中的列表为该类的所有实例共享,这些实例将任何东西传递给 __init__(定义 a = MyCollection([]),例如,将创建一个具有单独的 objs 列表的新实例)。

你应该使用:

def __init__(self, objs=None):
    if objs is None:
        objs = []

涵盖此内容的规范问题:"Least Astonishment" and the Mutable Default Argument

关于python - 覆盖对象实例不释放内存?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21382625/

相关文章:

python - 如何在不使用 ctrl-c 的情况下关闭 jupyter notebook 应用程序(服务器)?

python - 拦截(使用 Python)从另一个进程写入文件的数据

c# - 将变量绑定(bind)到列表

node.js - nodejs垃圾收集输出

ruby - 如何解决由于 Ruby 中的垃圾回收引起的偶发性崩溃

python - Python 中每个值有多个键的字典

python - 检查 Pair Series 值以查看它们是否在列表中

python - Tkinter:整个应用程序的一大类

ruby-on-rails - Ruby on Rails - 从父类调用每个子类的方法

ruby-on-rails - Ruby 2.1.5 - GC 调整