理解实例和类变量python

时间:2012-06-02 12:13:48

标签: python

假设我在不同场景中有2个班级。

情景1

class MyClass():
    temp = 5

场景2

class MyClass():
    temp = 5

    def myfunc(self):
          print self.temp

现在什么时候变量temp将被视为类变量和实例变量。我很困惑,因为在这两种情况下我都可以使用两者来访问变量temp的值。

  1. Object.Temp(表现为实例变量)

  2. ClassName.Temp(表现为类变量)

  3. 我相信之前已经提出了类似的问题,但如果有人可以在我的问题的背景下解释这个问题,这将是一个很大的帮助。

3 个答案:

答案 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是一个类变量。当你访问变量时,它会通过继承层进行搜索,因此在实例本身中找不到它,它会检查类(下一层)并在那里找到它。