对任何一个父类调用__init__都不会改变类的继承结构,不。您只是在更改创建实例时除了C.__init__之外还运行什么初始化器方法。C同时继承{}和{},并且由于继承顺序的不同,{}的所有方法都被{}上的方法所遮蔽。在
如果需要根据构造函数中的值更改类继承,请创建两个不同结构的独立类。然后提供另一个可调用的API来创建实例:class CA(A):
# just inherit __init__, no need to override
class CB(B):
# just inherit __init__, no need to override
def C(path):
# create an instance of a class based on the value of path
class_map = {'A': CA, 'B': CB}
return class_map[path](path)
API的用户仍然有名称C()来调用;C('A')从C('B')生成一个不同类的实例,但它们都实现了相同的接口,因此这对调用者来说并不重要。在
如果有一个公共的'C'类在isinstance()或issubclass()测试中使用,则可以混合使用一个,并使用^{} method重写返回的子类:
^{pr2}$
调用__new__来构造新的实例对象;如果__new__方法返回该类的实例(或其子类),则将自动对该新实例对象调用__init__。这就是为什么C.__new__()返回CA.__new__()或CB.__new__();__init__的结果。在
后者演示:&