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

本文只说现在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
    评论
Python中,__init__是一个特殊的方法,用于初始化一个类的实例。当创建一个类的实例,__init__方法会被自动调用。这个方法可以在创建实例进行一些初始化操作,比如设置实例的属性值或执行其他必要的操作。 而super()函数是用于调用父类的方法。在多重继承的情况下,如果一个子类继承了多个父类,那么在子类的__init__方法中,使用super().__init__()可以调用所有父类的__init__方法,以确保所有父类的初始化操作都被执行。 在引用的示例中,有一个多层次的继承结构,每个类的__init__方法中都通过super().__init__()调用了父类的__init__方法。这个调用顺序是按照广度优先的顺序进行的,即先调用最底层的父类的__init__方法,然后逐层向上调用父类的__init__方法。 总结起来,__init__方法用于初始化一个类的实例,在创建实例自动调用;而super().__init__()用于调用父类的__init__方法,确保多重继承中所有父类的初始化操作都被执行。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [pythonsuper().__init__()](https://blog.csdn.net/a__int__/article/details/104600972)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值