您可以在创建类之后更改元类,就像更改对象的类一样,但是会遇到很多问题。对于初学者,初始元类必须与
type,
__init__以及
__new__新元类的和都不会被调用(尽管您可以手动调用
__init__或执行
__init__s的方法
)。
更改元类的最麻烦的方法可能是从头开始重新创建该类:
B = metaClass(B.__name__, B.__bases__, B.__dict__)
但是,如果您坚持动态更改元类,则首先需要使用临时自定义元类定义B:
class _Tempmetaclass(type): passclass B: __metaclass__ = _Tempmetaclass # or: type('temp', (type, ), {})
然后,您可以像这样定义元类:
class metaClass(type): def __init__(cls, *a, **kw): super(metaClass, cls).__init__(*a, **kw) cls._actual_init(*a, **kw) def _actual_init(cls, *a, **kw): # actual initialization goes here
然后执行以下 *** 作:
B.__class__ = metaClassmetaClass._actual_init(B, B.__name__, B.__bases__, B.__dict__)
您还需要确保已完成该类的所有初始化
_actual_init。您也可以
classmethod向元类添加,以为您更改元类。
两种解决方案都有一个缺点,即B的基数会受到限制-它们必须与原始和新的元类都兼容,但是我想这对您来说不是问题。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)