python菱形继承_python多重继承和super

本文通过实例解析Python的菱形继承和多重继承,详细介绍了C3算法的规则,帮助理解`super`函数的工作原理。通过分析不同继承结构的`__mro__`方法,展示了类的继承顺序。
摘要由CSDN通过智能技术生成

本文只说现在python继承顺序采用的C3算法,只要弄明白C3算法,你就知道super函数的工作原理。  C3算法的规则如下  ①.从底层开始,选择入边为零的点。  ②.从左到右。  ③深度探索。但受限与②规则。  每一个类都可以用mro函数查看自己的继承顺序  例子1.菱形继承1    class D(object):  pass  class B(D):  pass  class C(D):  pass  class A(B,C):  pass  print(A.__mro__)  分析  ①规则。得到A类,去掉A类以后,入边为零的是B类和C类  ②规则。选择B类,去掉B类后,入边为零的只有C类。结论是A–>B–>C–>D。结果如下所示。  (, , , , )

2.菱形继承2

class F(object):

pass

class E(F):

pass

class D(F):

pass

class B(D):

pass

class C(E):

pass

class A(B,C):

pass

print(A.__mro__)

分析  ①规则,得到A类,去掉A类以后,入边为零的是B类和C类;  ②规则,得到B类,去掉B类以后,入边为零的D类和C类;  ③规则,深度探索得到D类,去掉D类以后入边为零的只有C类,继承顺序为A–>B–>D;  然后重复上述三步骤,得到继承顺序C–>E–>F。总的顺序为A–>B–>D–>C–>E–>F。运行结果如下。

(, , , , , , )

3.多重继承1

class G(object):

pass

class F(G):

pass

class E(G):

pass

class D(G):

pass

class B(D,E):

pass

class C(E,F):

pass

class A(B,C):

pass

print(A.__mro__)

分析  ①规则,得到A类,去掉A类以后,入边为零的是B类和C类。  ②规则,选择B类,去掉B类以后,入边为零的是D类和C类。  ③规则,选择D类,去掉D类以后,入边为零的是C类,所以得到继承顺序:A–>B–>D。  ①规则,得到C类,去掉C类以后,入边为零的是E类和F类。  ②规则,得到E类,去掉E类以后,入边为零的是F类,所以得到顺序是C–>E–>F–G。  总的继承顺序就是A–>B–>D–>C–>E–>F–G。结果如下。

(, , , , , , , )

4 多重继承2

class G(object):

pass

class F(G):

pass

class E(G):

pass

class D(G):

pass

class B(D,E):

pass

class C(D,F):

pass

class A(B,C):

pass

print(A.__mro__)

分析  ①规则,得到A类,去掉A类以后,入边为零的是B类和C类。  ②规则,选择B类,去掉B类以后,入边为零的是E类和C类。  ③规则,对于B类来说D类和E类都是基类,受限于②规则,继承顺序中D类一定在E类前面,但是D类有入边,所以后面只能选择C类。于是得到继承顺序A–>B。  ①规则,得到C类,去掉C类以后,入边为零的是D,E,F类。  ②后面D,E,F类顺序出现,所以得到继承顺序为C–>D–>E–>F–>G。总的继承顺序为A–>B–>C–>D–>E–>F–>G。结果如下。

(, , , , , , , )

如果你能明白上面所说的继承顺序,super函数工作原理就明白了。super(Class,self)这个函数就是获取继承顺序中的Class类的下一个类。

class X(object):

def out(self):

print('X')

class Y(object):

def out(self):

print('Y')

class Z(X,Y):

def out(self):

super(Z,self).out()#获取继承顺序中Z类下一个类,即X

class M(X,Y):

def out(self):

super(X,self).out()#获取继承顺序X类下一个类,即Y

Z().out()#输出X

M().out()#输出Y

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值