我有扎实的C/C++背景,所以如果我的问题很愚蠢,请容忍我。
这里我有两个声明来封装数据的类,
class Node:
Term = ""
TermInfo = []
def __init__(self,S,Info):
self.Term = S
self.TermInfo.append(Info)
class TermInfo:
DocID = 0
Freq = 0
def __init__(self,ID,F):
self.DocID = ID
self.Freq = F我试着用这种方式操纵它们
Info = TermInfo(ID,0)
node = Node(j,Info)
Dict[j] = node基本上,我试图构建一个包含由字符串"Term“和"Terminfo”列表组成的节点的字典,我期望每个节点都有自己的副本。但是,在我连续两次调用这三条线路之后,
Info = TermInfo(ID,0)
node = Node(j,Info)
Dict[j] = node
Info = TermInfo(ID,0)
node = Node(j,Info)
Dict[j] = node我很惊讶地看到两个"TermInfo“列表指向相同的内存地址,第二个append()也更改了第一个列表,那么如何确保每个节点都有自己的副本,而不是指向相同的地址呢?谢谢
发布于 2013-02-11 10:03:51
简短的回答:
在__init__中创建一个新列表。
def __init__(self,S,Info):
self.Term = S
self.TermInfo = [Info]长长的答案:
这与python查找属性的方式有关。当您这样做时:instance.attribute首先在实例上查找属性。如果在那里找不到,它将在类上查找该属性。在这里,您在类上有一个list属性,并且您一直通过实例附加到该属性。所以当你有了这行字:
self.TermInfo.append(whatever)Python首先看一看self。但是,self没有TermInfo属性,因此python会在self.__class__ (本例中为Node)中查找TermInfo属性--它会找到该属性并将其附加到Node.TermInfo列表中。
发布于 2013-02-11 10:06:35
只有在__init__中和对象构造之后分配的属性才是实例属性。类定义中分配的属性是类属性,类似于其他语言中的静态类成员。因此,如果您希望拥有每个实例的属性,请在__init__中指定它的初始值。
https://stackoverflow.com/questions/14804921
复制相似问题