Python类实例__dict__不包含所有实例变量.为什么?

Ina*_*ist 3 python class python-2.7

这里有一个关于实例变量的新手Python问题.

考虑以下Python 2.7类定义:

class Foo(object):
    a = 1

    def __init__(self):
            self.b = 2

    def __repr__(self):
            return "%s" % self.__dict__
Run Code Online (Sandbox Code Playgroud)

现在,当我创建一个实例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}
Run Code Online (Sandbox Code Playgroud)

在这里,我认为我对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
Run Code Online (Sandbox Code Playgroud)

所以,现在我覆盖了之前的值Foo.a,它会影响所有Foo没有别名的实例Foo.a:

>>> Foo.a=999
>>> x.a
999
>>> y.a
2
Run Code Online (Sandbox Code Playgroud)

Mar*_*ers 7

a不是实例变量.您将其定义为类的一部分.

>>> class Foo(object):
...    a = 1
...
>>> Foo.a
1
Run Code Online (Sandbox Code Playgroud)

如果需要实例变量,则应将其放在__init__方法中,因为在创建对象时会调用此方法.