系统相关
首页 > 系统相关> > python – 覆盖对象实例不释放内存?

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

作者:互联网

我有一个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

标签:circular-reference,python,class,garbage-collection
来源: https://codeday.me/bug/20190728/1563885.html