假设我在不同场景中有2个班级。
情景1
class MyClass():
temp = 5
场景2
class MyClass():
temp = 5
def myfunc(self):
print self.temp
现在什么时候变量temp
将被视为类变量和实例变量。我很困惑,因为在这两种情况下我都可以使用两者来访问变量temp
的值。
Object.Temp
(表现为实例变量)
ClassName.Temp
(表现为类变量)
我相信之前已经提出了类似的问题,但如果有人可以在我的问题的背景下解释这个问题,这将是一个很大的帮助。
答案 0 :(得分:6)
类变量在类的所有实例之间共享。对于不可变类型(如int,str,...),你不会注意到很多不同之处。但请考虑一下:
class MyClass():
temp = []
def myfunc(self, val):
self.temp.append(val)
print self.temp
instance1 = MyClass()
instance1.myfunc(1) # [1]
instance2 = MyClass()
instance2.myfunc(2) # [1, 2]
在这种情况下,两个实例共享相同的列表,即如果实例本身没有temp
成员,则使用该类。
所以如果你进一步做:
MyClass.temp.append(3)
print instance1.temp # [1, 2, 3]
instance1.temp = []
print instance1.temp # [] uses the instances temp
print instance2.temp # [1, 2, 3]
del instance1.temp
print instance1.temp # [1, 2, 3] uses the class' temp again
答案 1 :(得分:5)
基本上,MyClass.temp
始终是一个类变量。获取obj.temp
会返回类变量,直到您尝试设置obj.temp
,这会创建一个掩盖类变量的成员变量。我希望这会有所帮助:
>>> class MyClass(object):
... temp = 5
...
>>> a = MyClass()
>>> b = MyClass()
>>> a.temp
5
>>> b.temp
5
>>> b.temp = 6
>>> a.temp
5
>>> MyClass.temp = 7
>>> a.temp
7
>>> b.temp
6
>>> a.__dict__
{}
>>> b.__dict__
{'temp': 6}
>>> MyClass.__dict__
{..., 'temp': 7}
修改:在mata says时,append()
上的调用方法(例如obj.temp
)不算作“设置”它。
答案 2 :(得分:2)
temp
是一个类变量。当你访问变量时,它会通过继承层进行搜索,因此在实例本身中找不到它,它会检查类(下一层)并在那里找到它。