__new__我看到了元类的方法ABCMeta,并试图了解调用该方法时需要传递哪些参数。
def __new__(mcls, name, bases, namespace, /, **kwargs):
cls = super().__new__(mcls, name, bases, namespace, **kwargs)
_abc_init(cls)
return cls
作为示例,我将创建 abc 并使用它__new__来创建子类的实例。据我了解,__new__它调用一个方法__init__来初始化子类的实例。
示例代码:
class A(metaclass=abc.ABCMeta):
@abstractmethod
def func(self):
raise NotImplementedError
class B:
def func(self):
print("inheritance")
class C:
pass
现在我们可以使用以下方法B从注册派生类:Aregister
A.register(B)
而不是像往常一样实例化:
`obj = B()`
据我了解,我们可以调用该方法__new__:
A.__new__(...)
在这个阶段出现的问题是,__new__根据上面这个方法的源代码,我应该将什么作为参数传递给该方法?
嗯...你不需要做任何事情
A.__new__。当您创建类型的新对象A()或派生类型时,将调用此挂钩。该类型
B不是 的后代A。由于ABCMeta类中实现的机制,B它被认为是 的派生类A,但该类型A不包含在祖先类的列表中B,因此在创建对象时不会调用它B()A.__new__。该调用
A.__new__(A)将创建一个类型为 的新的未初始化对象A。该方法__new__在之前被调用__init__。实际上,这个方法应该为self中的参数分配内存A.__init__(self)。在绝大多数类中,方法
__new__都没有指定。对于这样的类,它被称为object.__init__,它为对象分配内存,并将类的链接分配给该对象。然后该类的构造函数用字段填充新创建的对象。__new__元类但对于元类,
__new__它的工作方式有所不同。当您创建一个新类时A,必须有人创建一个对象тип А。如果该类型A没有元类,则type.__new__('A', list-of-base-classes-of-A, map-of-members-of-A).此方法为类型分配内存A,用方法和静态字段填充它,并填充用于查找祖先的数据。但是如果一个类
A有元类,那么在为该类SomeMeta创建类型对象时,.事实上,这个方法还应该调用初始化,以便它可以继续其业务。例如,它遍历正在创建的类的方法并填充字典(考虑到继承)。这个字典在创建对象时学习一个方法- 如果字典不为空,则抛出异常Atype.__new__SomeMeta.__new__type.__new__AABCMeta.__new__A.__abstractmethods__object.__new__A()