技术文章 > Python技术 > Python基础 > 正文

python3中新类如何继承?

小妮浅浅

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新类的继承方法了,其中容易出错的地方,小编也有提到,大家仔细看一下避免出现同样的失误。

免费视频教程
本文原创发布python学习网,转载请注明出处,感谢您的尊重!
相关文章
 python3类中的def __init()__如何使用?
 python3类怎么学?可以应用于数学吗?
 python3类方法使用时需要注意什么?
 python3类中的装饰方法如何选择?
 python3类中的Dog如何用来转化?
 python3类中的Cat变量使用有限制吗?
 python3类中的super如何调用?
 python3类比函数好用吗?该如何选择?
 python3类对象需要在init中初始化吗?
相关视频章节
 Python类方法中的可用变量
推荐视频
视频教程分类