标签:style 使用 数据 问题 代码 new 算法 c++
类的成员变量
在Python里描述数据结构是使用类成员变量的方式,从上面的例子可以看到这样描述:
self.wndClass = WNDCLASSEX()
这行代码是写在类的构造函数里,通过使用类自身对象self来给类添加成员变量wndClass 。由于在Python语言里没有声明,每增加一个类成员变量,就是通过赋值的方式产生。不过,要注意的是Python语言里的成员变量是可以动态添加的,不但可以在构造函数里添加,也可以在成员函数里添加,更可以在类对象生成实例之后添加。如下面的例子:
class Foo: def __init__(self): print(‘__init__‘) def __del__(self): print(‘__del__‘) def foo(self): print(‘foo‘) self.sum = 100 print(‘%d‘ % (self.sum)) test = Foo() test.foo() test.newsum = 200 print(test.newsum)
在这个例子里,self.sum = 100这行代码是在类成员函数foo里添加成员变量;test.newsum = 200这行代码是在对象创建之后添加成员变量。类的成员变量在Python里是没有私有和公有的权限之分,所有成员变量都是公有的权限,也就是说对外面所有代码来说成员变量都是可以访问的。面对没有私有权限这个问题主要靠开发人员养成良好的习惯,不要在类外部访问类的成员变量,而是通过类的成员函数来调用,这样就会让封装的特性更好,如果类成员变量发生变化,如果类成员函数算法发生变化,类外面的调用代码都可以不作出改变,接口保持一致性,降低相互的依赖性,提高代码的复用性。
类的成员函数
在上面的例子里,像Register和foo都是类的成员函数,它的格式一般是这样:
def foo(self):
print(‘foo‘)
self.sum = 100
print(‘%d‘ % (self.sum))
也就是有这样的形式:
def 函数名称(self, 参数列表):
函数块
你看到这种形式时,也许会奇怪,为什么要有self参数?这个就是成员函数与普通函数的区别,比如下面的例子:
class Foo: def __init__(self): print(‘__init__‘) def __del__(self): print(‘__del__‘) def foon(): print(‘foon‘) def foo(self): print(‘foo‘) self.sum = 100 print(‘%d‘ % (self.sum)) Foo.foon() test = Foo() test.foo() test.newsum = 200 print(test.newsum) Foo.foon()
在这个例子里,非类成员函数foon,它的调用方式与成员函数的调用方式不一样,它使用的是类名和函数名称:Foo.foon(),而成员函数使用实例对象和函数名称:self.foo()。非成员函数可以没有产生实例的情况下使用,比如Foo.foon()。非成员函数比较像C++语言里的静态成员函数,不需要创建实例,但又达到命名空间的分隔作用。
标签:style 使用 数据 问题 代码 new 算法 c++
原文地址:http://blog.csdn.net/caimouse/article/details/38728301