python之super的使用小结
为什么需要super
在python没有引入super之前,如果需要在子类中引用父类的方法,一般写法如下:
classFather: defwhoami(self): print("Iamfather") classChild: defwhoami(self): print("Iamchild") Father.whoami(self)
这样看好像没什么问题,就算没有super也能正常调用父类的方法,但是如果有一天Father类需要修改类名为Father1,那么子类Child中也必须跟着修改.
想象下如果一个类有很多个子类,这样一来我们就需要修改每个子类中引用父类的语句
怎么使用super
Helponclasssuperinmodulebuiltins: classsuper(object) |super()->sameassuper(__class__,) |super(type)->unboundsuperobject |super(type,obj)->boundsuperobject;requiresisinstance(obj,type) |super(type,type2)->boundsuperobject;requiresissubclass(type2,type) |Typicalusetocallacooperativesuperclassmethod: |classC(B): |defmeth(self,arg): |super().meth(arg) |Thisworksforclassmethodstoo: |classC(B): |@classmethod |defcmeth(cls,arg): |super().cmeth(arg)
我们来看看super的帮助文档,首先super是一个类,它的调用方法有如下几种:
1.super()
2.super(type)
3.super(type,obj)
4.super(type,type2)
我们推荐用第一种方法来使用super,因为它并不需要显式传递任何参数.但是要注意一点,super只能在新式类中使用.
classA: def__init__(self): print("thisisA") classB(A): def__init__(self): super().__init__() print("thisisB") b=B() """ thisisA thisisB """
看起来super就像直接调用了B的父类A的__init__,其实并不是这样的,我们看看super在多继承下的使用
classA: def__init__(self): print("thisisA") print("leaveA") classB(A): def__init__(self): print("thisisB") super().__init__() print("leaveB") classC(A): def__init__(self): print("thisisC") super().__init__() print("leaveC") classD(B,C): def__init__(self): print("thisisD") super().__init__() print("leaveD") d=D() """ thisisD thisisB thisisC thisisA leaveA leaveC leaveB leaveD """ print(D.__mro__) """ (, , , , ) """
这里可以看到,如果super只是简单调用父类的方法的话,那么调用了B的__init__方法之后,应该调用A的__init__才对,但是调用的却是C的__init__方法
这是因为super调用的是当前类在MRO列表中的后一个类,而并不是简单地调用当前类的父类
python并没有强制性限制我们使用super调用父类,我们还是可以使用原始的方法来调用父类中的方法,但是需要注意的是调用父类的方法要统一,即全用super或全不用super,而用super的话,调用的方式也最好是统一的
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。