python多继承及其super的用法
class Class1: def m(self): print("In Class1") class Class2(Class1): def m(self): print("In Class2") class Class3(Class1): def m(self): print("In Class3") class Class4(Class2, Class3): def __init__(self): super(Class4, self).m() super(Class2, self).m() super(Class3, self).m() obj = Class4()
上面代码的输出结果为:
In Class2 In Class3 In Class1
看出区别了吗,区别就在于super中的第一个参数。python的多继承通常来说是按顺序继承的,但也不尽然! 它的多继承顺序是依据一个叫做**Method Resolution Order (MRO)**的算法来决定的,通过使用类名.mro()可以得到继承关系的顺序。 参考中的一个例子 如下图所示是一个比较复杂的继承关系图 其代码编写如下
# Demonstration of MRO class X: pass class Y: pass class Z: pass class A(X, Y): pass class B(Y, Z): pass class M(B, A, Z): pass print(M.mro())
而其输出结果为:
[<class __main__.M>, <class __main__.B>, <class __main__.A>, <class __main__.X>, <class __main__.Y>, <class __main__.Z>, <class object>]
在实际情况中,不可避免地会遇见这种比较复杂的继承关系,而要弄清楚它们的继承顺序似乎很是麻烦也容易出错,那么有没有办法直接指定调用某个基类的方法呢? 这当然是可以的。
class Class1: def m(self): print("In Class1") class Class2(Class1): def m(self): print("In Class2") class Class3(Class1): def m(self): print("In Class3") class Class4(Class2, Class3): def __init__(self): Class1.m(self) Class2.m(self) Class3.m(self) obj = Class4()
输出结果为:
In Class1 In Class2 In Class3
即,只需指定继承的类名,传入子类对象,即可调用任意指定基类的方法啦!