这不是一个自定义元类问题(尽管它是在元类阶段 诊断出来的 ):
>>> class Normal(object): pass... >>> class MyObject(object, Normal): pass... Traceback (most recent call last): File "<stdin>", line 1, in <module>TypeError: Error when calling the metaclass bases Cannot create a consistent method resolutionorder (MRO) for bases object, Normal
问题就和这个一样:
>>> class Derived(Normal): pass... >>> class Ok(Derived, Normal): pass... >>> class Nope(Normal, Derived): pass... Traceback (most recent call last): File "<stdin>", line 1, in <module>TypeError: Error when calling the metaclass bases Cannot create a consistent method resolutionorder (MRO) for bases Normal, Derived
即,不能将继承自基类的继承与继之以派生的类相乘-不可能定义一个满足常规MRO约束/保证的一致MRO。
幸运的是,您 不想 这样做-子类可能会覆盖基类的某些方法(这是普通子类;-的 作用) ,而将基类“置于前面”则意味着“将覆盖对象隐藏掉”。
将基类放在派生类 之后 是没有用的,但至少它是无害的(并且与常规MRO保证一致)。
您的第一个示例当然是有效的,因为
MyMixin它 不是 来自于
list:
>>> MyMixin.__mro__(<class '__main__.MyMixin'>, <type 'object'>)
…但是它 是 派生自的
object(就像每个现代风格的Python类一样),因此第二个示例无法工作(与
MyMixin拥有自定义元类无关)。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)