注:尚未在pyhon2中测试
参考文档:https://fishc.com.cn/forum.php?mod=viewthread&tid=48888&extra=page%3D1%26filter%3Dtypeid%26typeid%3D403
· 错误示例

——————————————————————————————————

class A():
def __init__(self):
self.a=10
def get_a(self):
print("我是a")
class B():
def __init__(self):
self.b=10
def get_b(self):
print("我是b")
B.__bases__ += (A,)
· 正确用法

class A():
def __init__(self):
self.a=10
def get_a(self):
print("我是a")
class Before_B():
pass
class B(Before_B):
def __init__(self):
self.b=10
def get_b(self):
print("我是b")
print(B.__bases__)
B.__bases__ += (A,)
在这里插入代码片由此可见,使用__bases__时,不继承__init__里的属性,只继承方法;为B类添加A类方法的前提是B是一个继承类,即B.__bases__为(<class ‘main.B的父类’>,)
· 查看继承的类,MRO
使用 print(类名._mro_) 可查看继承的顺序。
参考文档《一窥Python中MRO排序原理》,可以看出是深度优先的原则。
参考文档《多重继承的陷阱:钻石继承(菱形继承)问题》则写着广度优先。
?????

本文详细解析了Python中多重继承的正确实践,特别是__bases__属性的运用,对比了错误与正确的示例,揭示了继承过程中方法与属性的继承特性,并探讨了MRO排序原则。
226

被折叠的 条评论
为什么被折叠?



