python中分为旧类和新类,因为小编使用的是主流的python3版本,所以我们本篇文章讲的是新类。那么在新类的继承中,我们需要注意哪些事项呢?因为有不少小伙伴有这种疑问,所以小编赶紧搜集了新类方面的资料,大家一起来学习一个示例,我们把这个问题一起解决出来。
首先说明一个问题,Python的多重继承确实正如文档所言是深度优先从左至右不重复,唯一的问题是,关于优先其实是指最贴近继承树叶部的,左侧的优先,会最后继承,从而覆盖其它继承得来的效果。在Python里,当新构造一个对象时,有两个步骤:首先是自底向上,从左至右调用__new__,然后再依照递归栈依次调用__init__。这个问题可以用以下代码说明。
class A: def __new__(cls, *argv, **kwargs): print('nA') return super().__new__(cls) def __init__(self, a): print('A') self.a = a def comeon(self): print('A.comeon') class B(A): def __new__(cls, *argv, **kwargs): print('nB') return super().__new__(cls) def __init__(self, b): super().__init__(b) print('B') self.b = b def comeon(self): print('B.comeon') class C(A): def __new__(cls, *argv, **kwargs): print('nC') return super().__new__(cls) def __init__(self, c): super().__init__(c) print('C') self.c = c def comeon(self): print('C.comeon') class D(B, C): def __new__(cls, *argv, **kwargs): print('nD') return super().__new__(cls) def __init__(self, d): super().__init__(d) print('D') self.d = d d = D('d') d.comeon()
首先看到:d.comeon是从左自右得来的左边的那个B的comeon。那么如何实现这样的效果呢?很简单,让B的init最后一个执行,就能覆盖掉C和D写入的comeon。
所以实际调用new的顺序就是D–B–C–A,之后递归栈回过头来初始化,调用init的顺序就是A–C–B–D,只有这样才能保证B里的comeon能够覆盖掉D的init带入的comeon和C带入的comeon,同样保证如果你的D里有个comeon,它是最后一个init的,将最后写入而覆盖掉其它的。
相信小伙伴们已经学会python3新类的继承方法了,其中容易出错的地方,小编也有提到,大家仔细看一下避免出现同样的失误。
神龙|纯净稳定代理IP免费测试>>>>>>>>天启|企业级代理IP免费测试>>>>>>>>IPIPGO|全球住宅代理IP免费测试