所以多继承传参数是不是不能用super()?因为这样单独使用父类实例的时候会因参数不匹配而出问题。或者只能父类使用if语句来根据情况判断所传递的参数 本节讲了几个重要的概念:首先是构造函数,即__init(),可在实例化对象的同时实现个性化定制,自动调用,百花齐放;其次是重写,是指继承时子类重新写一个同名的属性或方法对父类进行覆盖,实现“造反”;接着是钻石继承,是在调用未绑定的父类方法时可能产生的问题,被两个类同时继承的父类的构造函数在两个类的子类实例化对象时被重复调用了两次,看似拥有“双倍快乐”,实则承担“双倍风险”,可通过调用super()函数来解决。super()函数能够在父类中按照“MRO”(Method Resolution Order,方法解析顺序,可通过类的mro()方法或__mro__属性来获取)搜索指定的方法,并自动绑定好self参数,避免重复调用,十分智能!只不过,我们要先搞懂“MRO”可能很迷的排序规则,方能正确合理地使用super()函数。 Learning...{:10_260:} {:10_266:} >>> class B1(A):
... def __init__(self):
... super().__init__()
... print("哈喽,我是B1~")
...
>>> class B2(A):
... def __init__(self):
... super().__init__()
... print("哈喽,我是B2~")
...
>>> class C(B1, B2):
... def __init__(self):
... super().__init__()
... print("哈喽,我是C~")
...
>>> c = C()
哈喽,我是A~
哈喽,我是B2~
哈喽,我是B1~
哈喽,我是C~
最后输出 为什么先输入B2,后面是B1呢? 打卡 tianqi2007 发表于 2023-1-8 11:25
>>> class B1(A):
... def __init__(self):
... super().__init__()
同问,求解答 tianqi2007 发表于 2023-1-8 11:25
>>> class B1(A):
... def __init__(self):
... super().__init__()
MRO 顺序是C-B1-B2-A, 所以返回值是按逆序列B2-B1 而不是B1-B2 {:10_257:}{:10_257:}{:10_257:} wang_mark2023-2-23 01:35
MRO C-B1-B2-A B2-B1 B1-B2
B2B1
A~
B1~
A~
B2~
C~ MRO 顺序是C-B1-B2-A这个理解,所以输出时候是A-B2-B1-C这个顺序,那为什么钻石继承时候输出是先B1后B2呢? 顺序不应该是一样的么?只不过是输出几次A的问题 {:10_258:}
页:
[1]