Python作为一个面向对象的脚本语言。这样就很类似于C++ 和JAVA这样的类关系。但是又有自己的特点。在
使用父类的所有函数时。一定要在子类申明有效之后。不然。即使在代码中你看到自己的已经对父类在子类中
进行了实例化或声明,但是这个时候是无效声明。因为你在使用父类之后进行了声明。
会提示您类似于这样的错误提示:
NameError: global name 'mainwin' is not defined。。。。。。
但是你又看到自己的函数中确实进行了对mainwin 的申明。
这就是因为在申明的时候和使用的先后.
每个类可以拥有一个或者多个父类,它们从父类那里继承了属性和方法。如果一个方法在子类的实例中被调用,
或者一个属性在子类的实例中被访问,但是该方法或属性在子类中并不存在,那么就会自动的去其父类中进行查找。
继承父类后,就能调用父类方法和访问父类属性,而要完成整个集成过程,子类是需要调用的构造函数的
子类不显式调用父类的构造方法,而父类构造函数初始化了一些属性,就会出现问题
如果子类和父类都有构造函数,子类其实是重写了父类的构造函数,如果不显式调用父类构造函数,父类的构造函数就不会被执行,
导致子类实例访问父类初始化方法中初始的变量就会出现问题。
class A:
def __init__(self):
self.namea="aaa"
def funca(self):
print "function a : %s"%self.namea
class B(A):
def __init__(self):
self.nameb="bbb"
def funcb(self):
print "function b : %s"%self.nameb
Result:
b=B()
print b.nameb
b.funcb()
b.funca()
bbb
function b : bbb
Traceback (most recent call last):
File "D:\workbench\python\MyPythonProject\test\study\overwrite_method.py", line 19, in <module>
print b.funca()
File "D:\workbench\python\MyPythonProject\test\study\overwrite_method.py", line 6, in funca
print "function a : %s"%self.namea
AttributeError: B instance has no attribute 'namea'