python super 继承_Python类继承自object为什么要super自己的方法?

一种特殊的多继承方式,要记住super()的结果不一定就是你在类的继承列表后面写的第一个类,例如

class A(object):

...

class B(object):

def test_super(self):

super().some_func

...

class C(B,A):

....

则对于B的实例来说,super()是object类;但对于C的实例来说,test_super()中的super(),会指向A,因为C的__mro__实际上是(C,B,A,object)。而且继承列表中类的顺序也会对mro有影响,如果B和A交换顺序,则super()就都是object了。

所以这个类的用法需要配合其他提供get_context_data方法的类,这里的实现是指向那个mro列表中更靠后的类的实现,也就是为它提供了另一层包装。

顺便提一句,mro列表的生成实际上是非常复杂的,类似于拓扑排序,它保证mro列表中继承的类出现在被继承的类之前,同一级继承的多个类的先后顺序和mro中的先后顺序相同,因此某些多继承在定义的时候可能会直接报错。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值