Python 多重继承时metaclass conflict问题解决与原理探究( 二 )


解决方案那理想情况下C的metaclass到底应该是什么呢?理想情况应该如下所示:
M0M1 : \/ : :\ /: AM2B\:/\ : /C即采用多继承了M0、M1的M2作为C的metaclass,这也是解决这个问题的最终方案 , 具体代码如下:
In [58]: class M2(M0, M1):...:pass...:In [59]: class C(A, B, metaclass=M2):...:pass...:如上我们通过手动定义M2,并手动明确指定class C的metaclass为M2 , 如此解决metaclass conflict问题 。这时再回到开头碰到的多继承abc.ABC与admin.ModelAdmin时遇到的问题就很容易理解了:因为abc.ABC有自己的metaclass abc.ABCMeta,同时modelAdmin也有自己的metaclass django.forms.widgets.MediaDefiningClass , 并且这两者之间没有继承关系 , 因而 class MyAdmin(abc.ABC, admin.ModelAdmin) 多继承时解释器无法推断出满足条件的metaclass,自然也就报错了 , 解决办法和上面的方案一样,定义一个两者metaclass的子类并将其指定为MyAdmin的metaclass即可,代码如下:
In [112]: print(type(abc.ABC), type(admin.ModelAdmin))<class 'abc.ABCMeta'> <class 'django.forms.widgets.MediaDefiningClass'>In [113]: class MyMeta(type(abc.ABC), type(admin.ModelAdmin)):...:pass...:In [114]: class MyAdmin(abc.ABC, admin.ModelAdmin, metaclass=MyMeta):...:pass...:In [115]: print(type(MyAdmin))<class '__main__.MyMeta'>转载请注明出处 , 原文地址:python_metaclass_conflict_study.html" rel="external nofollow noreferrer">https://www.cnblogs.com/AcAc-t/p/python_metaclass_conflict_study.html
参考https://www.liaoxuefeng.com/wiki/1016959663602400/1017592449371072python" rel="external nofollow noreferrer">https://stackoverflow.com/questions/100003/what-are-metaclasses-in-pythonhttps://www.cnblogs.com/JetpropelledSnake/p/9094103.htmlpython/metatype.html" rel="external nofollow noreferrer">http://www.phyast.pitt.edu/~micheles/python/metatype.html

推荐阅读