这里有一些关于实例变量的新手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 docs我看到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
答案 0 :(得分:6)
您的a
不是实例变量。您将其定义为该类的一部分。
>>> class Foo(object):
... a = 1
...
>>> Foo.a
1
如果你想要一个实例变量,你应该把它放在__init__
方法中,因为在创建对象时会调用这个方法。
答案 1 :(得分:3)
a
不是实例属性,它是类属性。
答案 2 :(得分:0)
这可以帮助你进一步吗?
>>> class X(object):
def __getattribute__(self, name):
print name
return object.__getattribute__(self, name)
>>> l = dir(X())
__dict__
__members__
__methods__
__class__
>>> l
['__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__', '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__']