Python 继承之构造函数的说明
在 Python 中,如果子类不重写 __init__,实例化子类时,就会自动调用父类的 __init__:
class Father(object):
def __init__(self, name):
self.name=name
print ( "name: %s" %( self.name) )
def getName(self):
return 'Father ' + self.name
class Son(Father):
def getName(self):
return 'Son '+self.name
if __name__=='__main__':
son=Son('yujx')
print ( son.getName() )
结果为:
name: yujx
Son yujx
如果重写了__init__ 时,实例化子类,就不会调用父类已经定义的 __init__:
class Father(object):
def __init__(self, name):
self.name=name
print ( "name: %s" %( self.name) )
def getName(self):
return 'Father ' + self.name
class Son(Father):
def __init__(self, name):
print ( "hi" )
self.name = name
def getName(self):
return 'Son '+self.name
if __name__=='__main__':
son=Son('yujx')
print ( son.getName() )
结果为:
hi
Son yujx
因此如果在子类中需要父类的构造方法就需要显式地调用父类的构造方法,或者不重写父类的构造方法,那么如果显示的调用父类的构造方法呢?接下来就带大家学习一下 super 关键字的使用。
Super() 函数
super() 函数是用于调用父类(超类)的一个方法。
super 是用来解决多重继承问题的,直接用类名调用父类方法在使用单继承的时候没问题,但是如果使用多继承,会涉及到查找顺序(MRO)、重复调用(钻石继承)等种种问题。
MRO 就是类的方法解析顺序表, 其实也就是继承父类方法时的顺序表。
语法:
super(type[, object-or-type])
- type -- 类;
- object-or-type -- 类,一般是 self。
Python3.x 和 Python2.x 的一个区别是: Python 3 可以使用直接使用 super().xxx 代替 super(Class, self).xxx :
# Python3.x 实例
class A:
def add(self, x):
y = x+1
print(y)
class B(A):
def add(self, x):
super().add(x)
b = B()
b.add(2) # 3
# Python2.x 实例
class A(object): # Python2.x 记得继承 object
def add(self, x):
y = x+1
print(y)
class B(A):
def add(self, x):
super(B, self).add(x)
b = B()
b.add(2) # 3