字典作为默认类参数是为所有类实例共享的,为什么?

时间:2012-03-29 18:27:33

标签: python python-2.7

  

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

我只是在玩蟒蛇游戏,偶然发现了令我困惑的事情。

为什么下面代码中的t1和t2共享相同的决策字典?我必须写

t1=Decision({},txt1="Test1",txt2="Response Test1")

而不是

t1=Decision(txt1="Test1",txt2="Response Test1")

让他们各自拥有一个。为什么呢?

如果有任何重要性,我会使用Python 2.7。

class Decision(object):
    def __init__(self,decisions={},txt1="",txt2=""):
        self.decisions=decisions
        self.txt1=txt1
        self.txt2=txt2
    def run(self):
        if len(self.decisions)>0:
            print self.txt1
            print self.txt2
            for i in self.decisions: print i + " - " + self.decisions[i][0]
            ans=""
            while True:
                ans=raw_input("Enter answer: ")
                if ans in self.decisions: break
            if self.decisions[ans][1] is not None: self.decisions[ans][1].run()


t1=Decision(txt1="Test1",txt2="Response Test1")
t2=Decision(txt1="Test2",txt2="Response Test2")    

t1.decisions["yes1"]=("Yes","t2")
t1.decisions["no1"]=("No","t3")

t2.decisions["yes2"]=("Yes","t3")
t2.decisions["no2"]=("No","t1")

print t1.decisions
<<<{'no2': ('No', 't1'), 'no1': ('No', 't3'), 'yes1': ('Yes', 't2'), 'yes2': ('Yes', 't3')}
print t2.decisions
<<<{'no2': ('No', 't1'), 'no1': ('No', 't3'), 'yes1': ('Yes', 't2'), 'yes2': ('Yes', 't3')}
顺便说一下。我解决了这个问题:

class Decision(object):
    def __init__(self,decisions=None,txt1="",txt2=""):
        if decisions==None:self.decisions={}
        else:self.decisions=decisions
        ...

但我想知道原因。我现在为什么不应该更容易记住不要这样做。

1 个答案:

答案 0 :(得分:1)

因为创建空dict的def(inition)行是在方法定义时计算的,而不是方法调用的时间。