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的话,调用的方式也最好是统一的
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。