Python父类的两种写法及优缺点

总结父类的两种写法及优缺点

写法一:使用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函数能有效的保证继承链上的方法被正确调用到。


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