[Python]成员变量与类变量

前几天偶然间踩坑后发现了python的类变量(ClassVar)有一个特性,使用成员变量(MemberVar)的调用形式self.varName调用的居然是类变量!

这还不够,当有同名的成员变量self.varName**被定义且被赋值**后使用self.varName调用的将不再是类变量而是成员变量!

结论说起来可能有点绕,不如来看下这个例子:

例1. 类变量

class Func():
    nClassVar = 1
    def __init__(self):
        pass
    def Add(self):
        Func.nClassVar += 1
    def PrtCountNum(self):
        print('self:%d,class:%d' % (self.nClassVar, Func.nClassVar))

func = Func()
func.PrtCountNum()
func.Add()
func.PrtCountNum()

在例1中我定义了一个类变量,然后分别用了成员变量的调用形式和类变量的调用形式,结果如下

self:1,class:1
self:2,class:2

可以看到两种调用形式得到的都是都一个值,也就是类变量。

但是如果我有一个同名的成员变量self.nClassVar之后会是怎样,稍微改一下构造方法和Add方法:

例2. 成员变量

class Func2():
    nClassVar = 1
    def __init__(self):
        self.nClassVar = 2
    def Add(self):
        self.nClassVar += 1
    def PrtCountNum(self):
        print('self:%d,class:%d' % (self.nClassVar, Func2.nClassVar))

func = Func2()
func.PrtCountNum()
func.Add()
func.PrtCountNum()

输出如下:

self:2,class:1
self:3,class:1

很明显,在构造方法中定义了成员变量nClassVar后,使用self.nClassVar得到的将会是成员变量值。

这里有一个细节,如果我在例2的构造方法中不定义成员变量,使用pass,那么在Add方法中的代码

self.nClassVar += 1
相当于
self.nClassVar = Func2.nClassVar + 1

那么得到的输出将会是:

self:1,class:1
self:2,class:1

废话这么多,其实就是我太菜,在改其它人代码的时候没注意这个细节,还以为能用self.nClassVar得到的都是成员变量←◡←。


版权声明:本文为ce1061183126原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。