日常报错 TypeError: Cannot create a consistent method resolution
今天在学习使用Ctrl+H、Ctrl+Shift+H的用处时,随便写了几个类的继承举例来测试,结果运行一下出现报错了TypeError: Cannot create a consistent method resolution无法创建一致的方法解析修正后代码截图如下:定位到报错的位置,改了一些继承类A、B的顺序就好了。究其原因:类C想要继承A和B,由于B已经继承A了,写成class ...
今天在学习使用Ctrl+H、Ctrl+Shift+H的用处时,随便写了几个类的继承举例来测试,结果运行一下出现报错了
TypeError: Cannot create a consistent method resolution
无法创建一致的方法解析
修正后代码截图如下:
定位到报错的位置,改了一些继承类A、B的顺序就好了。
究其原因:类C想要继承A和B,由于B已经继承A了,写成class C(A, B)
错误形式时,python无法确定先查找哪些类的方法,于是无法覆盖定义在A中定义的方法。其实没有必要再继承一下A,因为既然B已经继承A了,那只要继承一下B就行了。
另外,在查找实例属性/方法时,python需要决定按哪个顺序搜索(直接和间接)基类。它通过线性化继承图来实现这一点,也就是通过使用一种叫做c3或mro的算法将基类图转换成序列。MRO算法是一种独特的算法,可实现以下几个理想特性:
- 每个祖先类只出现一次
- 类总是出现在其祖先之前(“单调性”)。
- 同一类的直接父类应按照类定义中列出的顺序显示(“一致的本地优先顺序”)。
- 如果A类的子类总是出现在B类的子类之前,则A应出现在B类之前(“一致的扩展优先顺序”)。
这里的话,第二个特性要求B首先出现,而自己的代码错误写成要求A首先出现,由于无法满足所有特性,报错提示。
为了博友copy code验证:
class A(object):
def __init__(self, name):
self.name = name
def get(self):
return self.name
class B(A):
def get(self):
super(B, self).get()
class C(B, A): # class C(A, B): 错误写法
def get(self):
super(C, self).get()
c = C("Name")
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)