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

时间:2014-01-27 13:52:30

标签: 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)

1 个答案:

答案 0 :(得分:7)

我会毫不犹豫地猜测你现在有这样的事情:

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