Python类实例__dict__并不包含所有实例变量。为什么?
问题内容:
这是关于实例变量的Python新手问题。
考虑以下Python 2.7类定义:
class Foo(object):
a = 1
def __init__(self):
self.b = 2
def __repr__(self):
return "%s" % self.__dict__
现在,当我创建的实例时Foo
,Foo.__dict__
包含b
,但不是a
。
>>> x=Foo()
>>> x
{'b': 2}
>>> dir(x)
['__class__', '__delattr__', '__dict__', '__doc__', '__format__',
'__getattribute__', '__hash__', '__init__', '__module__', '__new__',
'__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__',
'__str__', '__subclasshook__', '__weakref__', 'a', 'b']
>>> x.__dict__
{'b': 2}
在这里,我认为我对Python的方式掌握得很好。
x.a
和之间有什么区别x.b
?据我所知,它们都是实例变量。
编辑 :好的,重新阅读Python文档,我看到这Foo.a
是一个 类属性,
而不是实例变量。嗯…我猜是因为我可以给它分配一个新值,x.a
而这个新值仅影响x
实例,所以我感到困惑-
我想我现在是在Foo.a
属性顶部别名一个成员变量:
>>> y=Foo()
>>> y.a = 2
>>> y
{'a': 2, 'b': 2}
>>> x
{'b': 2}
>>> x.a
1
>>> z=Foo()
>>> z
{'b': 2}
>>> z.a
1
>>> Foo.a
1
>>> x.a
1
>>> y.a
2
因此,现在我覆盖的先前值Foo.a
,它会影响所有Foo
未别名的实例Foo.a
:
>>> Foo.a=999
>>> x.a
999
>>> y.a
2
问题答案:
您a
不是实例变量。您将其定义为类的一部分。
>>> class Foo(object):
... a = 1
...
>>> Foo.a
1
如果需要实例变量,则应将其放在__init__
方法中,因为在创建对象时会调用此方法。