多重继承 | Python

Multiple inheritance | Python

为什么在这段代码中没有调用 A:[是不是因为 mro : 从左到右然后应该调用 A class?]

class A:
    
     def __init__(self,name):
        print('inside a',name)
        
class B:
    
     def __init__(self,name):
        print('inside b',name)
        
class C(B,A):
    
     def __init__(self,name):
        print('inside c',name)
        super().__init__(name)
        
c = C('hello')

输出:

inside c hello

inside b hello

但是当我这样定义它时,它基本上是一个父 class 然后它按预期正常工作。[为什么 A class 在这里被调用]代码:

class D:
    
    def __init__(self,name):
        print('inside d',name)
    
class A(D):
    
     def __init__(self,name):
        print('inside a',name)
        super().__init__(name)
        
class B(D):
    
     def __init__(self,name):
        print('inside b',name)
        super().__init__(name)
        
class C(B,A):
    
    def __init__(self,name):
        print('inside c',name)
        super().__init__(name)
        
c = C('hello')

输出:

inside c hello

inside b hello

inside a hello

inside d hello

根据方法解析顺序,以深度优先搜索方法搜索成员,即在您的第一个示例中:

class A:
    
     def __init__(self,name):
        print('inside a',name)
class B:
    
     def __init__(self,name):
        print('inside b',name)       


class C(B,A):
    
     def __init__(self,name):
        print('inside c',name)
        super().__init__(name)
        
c = C('hello')

首先:调用了C的构造函数。

其次: 因为你有 super().init(name) 在你 class C 中,它会调用它的左父即 B.

第三: 它会尝试向右移动(class C)但是因为你还没有写 super().init(name) inside class B ,无法调用 class A 的构造函数,因为无法从 class B 移动到 Object class

                            Object
                             /\
                            /  \
                           B    A
                            \  /
                             \/
                             C 

如果你将在 class B 中编写 super().init(name) ,它将从对象 class 迭代到对象的右侧,即class一个

例如:

class A:
    
     def __init__(self,name):
        print('inside a',name)
        
class B:

     def __init__(self,name):
        print('inside b',name)
        super().__init__(name)

        
class C(B,A):
    
     def __init__(self,name):
        print('inside c',name)
        super().__init__(name)

        
c = C('hello')

更多请访问:https://www.geeksforgeeks.org/method-resolution-order-in-python-inheritance/