多重继承 | 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/
为什么在这段代码中没有调用 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/