class C:
count=0
a=C()
b=C()
c=C()
print(a.count)
print(b.count)
print(c.count)
c.count+=10
print(c.count)
print(a.count)
print(b.count)
print(C.count)
C.count+=100
print(a.count)
print(b.count)
print(c.count)
0
0
0
10
0
0
0
100
100
10
为什么后来a.count b.count的值都是100 而c.count的值是10
因为c.count+=10 相当于给c这个实例对象动态的加了一个实例属性,打印c.count的时候会打印出实例属性而不是类属性
In [1]: class C:
...: c= 10
...:
In [2]: c = C()
In [3]: c.c
Out[3]: 10
In [4]: c.c = 1000
In [5]: c.__dict__
Out[5]: {'c': 1000}
In [6]: c.__class__.__dict__
Out[6]: {'__doc__': None, '__module__': '__main__', 'c': 10}
In [7]: c.__class__.c
Out[7]: 10
In [8]:
可以一步步看。
首先实例化三个C的类对象。
打印a, b, c的count值。
这里涉及到一个属性的查找顺序。
首先,查找实例是否有count值,发现找不到,则会查找上一级。实例的上一级是类,发现类属性中有count,则输出这里的count。
c.count += 10
原本c.count引用的是C.count,但现在给它赋了一个新值,就相当于c实例有了count这个属性。
打印a, b, c, C的count值。此时实例c已经有了自己的count值。
C.count += 100
改变类C的count值。c有自己的count值,a, b依然引用C的count值。
大概就是这个样子。