总结父类的两种写法及优缺点
写法一:使用FatherClassName.init(self,par1,para2)
子类的初始化方法里面,继承使用父类的属性和方法需要显式的调用父类的初始化方法 init,而且要传入相应的参数。
class SonClassName(FatherClassName):
price = 1
model = 'Type1'
def __init__(self,par1,para2,Tur):
# 先调用父类的初始化方法
FatherClassName.__init__(self,par1,para2)
self.par1 = Tur
self.par2 = 4
def sonFun():
pass
方法二:使用super()函数
class SonClassName(FatherClassName):
def __init__(self,fp1,fp2,p3):
# 同样是调用父类的初始化方法
super().__init__(fp1, fp2)#方法参数中不需要加上 self 参数。
self.p3 = p3
self.p4 = 10
优点:
1、代码维护性好:子类中调用父类的方法,不需要显式指定父类的名字。
想象一下,如果fatherClassName有很多子类,如果那一天fatherClassName类改了名字,采用super这样的写法,就不需要修改子类的代码了。
2.多重继承不容易出错–在多重继承的情况,super函数能有效的保证继承链上的方法被正确调用到。