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