时间:2021-05-22
python中有两种方法可以调用父类的方法:
super(Child, self).method(args)
Parent.method(self, args)
我用其中的一种报了如下错误:
找不到 classobj。当我把调用改为 super(B, self).f(name) 就能正确运行,且结果正确。
分析错误
因为基类没有继承 object , 在python中,一个可以这样创建:
class A: pass也可以这样创建:
class A(object): pass这两者的区别就是:
这是老式类(前者)和新式类(后者)的区别。区别可以参考:https://docs.python.org/release/2.5.2/ref/node33.html
python3已经把旧类型去掉了,也就是说已经隐式继承了object,所以,python3中写不写继承object都是没有区别的
两种调用的区别
Parent.__init__(self) 与 super(Child, self).__init__() 的区别是什么?
super 理解成父类也是理所当然,python里其实指的是 MRO 中的下一个类!
super其实干了这件事,看这个答案:
def super(cls, inst): mro = inst.__class__.mro() # Always the most derived class return mro[mro.index(cls) + 1]MRO 全称 Method Resolution Order,它代表了类继承的顺序。
super 是用来解决多重继承问题的,假设B C D 都是直接继承class A
class E(B, C, D): def __init__(self): # code...如果E类的构造函数使用 super(E, self).__init__() 时,A类的构造函数会被执行一次,而用另一种方法,A类的构造函数会被执行多次。
在 MRO 中,基类永远出现在派生类后面,如果有多个基类,基类的相对顺序保持不变。
总结
个人觉得,复杂的继承结构是设计中不良的设计,当继承结构清晰后,两个方法其实就没什么区别了。以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
通过子类调用父类的变量,有两种方法:1、把父类的变量设置成public:packagetriangle.opengl.wlz.stu.childusefathe
本文实例讲述了Python实现子类调用父类的方法。分享给大家供大家参考。具体实现方法如下:python和其他面向对象语言类似,每个类可以拥有一个或者多个父类,它
我们需要对类按照类中的某一个属性(或者多个属性)来对类的对象进行排序,有两种方法可以实现,一种方法是类实现Comparable接口,然后调用Collection
一、总结1.子类创建对象时会调用父类的构造方法2.采用super显示声明了就是调用这个显示声明的父类构造方法,没有则默认调用父类的那个空构造方法(父类中声明了带
python系统调用的实例详解本文将通过两种方法对python系统调用进行讲解,包括python使用CreateProcess函数运行其他程序和ctypes模块