为什么实例变量在Python中表现得像一个类变量?

时间:2012-10-30 17:25:10

标签: python class variables instance

  

可能重复:
  “Least Astonishment” in Python: The Mutable Default Argument

我有以下代码:

class Node(object):
    def __init__(self, value = 0, children = {}):
        self.val = value
        self.children = children

    def setChildValue(self, index, childValue):
        self.children[index] = Node(childValue)

n = Node()
n.setChildValue(0,10)
print n.children
n2 = Node()
print n2.children

它打印出来:

{0: <__main__.Node object at 0x10586de90>}
{0: <__main__.Node object at 0x10586de90>}

所以我的问题是,为什么在n2中定义了孩子? Children是一个实例变量,但它就像一个类变量。

由于

3 个答案:

答案 0 :(得分:4)

您在每个实例上为children分配相同的字典。

答案 1 :(得分:2)

定义函数__init__时,将字典作为默认参数。该字典创建一次(当您定义函数时),然后每次调用__init__时使用。

更多信息: http://effbot.org/zone/default-values.htm

答案 2 :(得分:1)

正如Martijn的评论和kindall的回答所示,你正在遇到可变的默认参数行为,它在某些时候咬了大多数Python开发人员,这里是你如何修改Node.__init__()以便它按你期望的方式工作:

class Node(object):
    def __init__(self, value = 0, children = None):
        self.val = value
        if children is None:
            self.children = {}
        else:
            self.children = children