5分钟了解 Python 中的super函数是如何实现继承的

Python

Py 2.x 和 Py 3.x 中有一个很大的区别就是类,不管是类的定义仍是类的继承。Py 3.x 中类的继承能够直接使用 super() 关键字代替原来的 super(Class, self)。python

那么 super() 究竟是依据什么来继承的呢?今天就来分析下。架构

super()函数根据传进去的两个参数具体做用以下:函数

经过第一参数传进去的类名肯定当前在MRO中的哪一个位置。MRO(Method Resolution Order);学习

经过第二个参数传进去的self,肯定当前的MRO列表。大数据

def super(cls, inst):
   mro = inst.__class__.mro() #肯定当前MRO列表
   return mro[mro.index(cls) + 1] #返回下一个类

以下代码:code

class A(object):
	def name(self):
	    print('name is xiaoming')    
	    #super(A,self).name()

class B(object): 
	def name(self):
	    print('name is cat')
      
class C(A,B):
	def name(self):
	    print('name is wang')
	    super(C,self).name()if __name__ == '__main__':

c = C()
print(c.__class__.__mro__)
c.name()

执行以上代码输出:当执行C类下的super()函数时,实际调用了A类下的name函数。A中注释掉了super()函数,因此并无向后继续执行。而且打印出了当前MRO列表顺序为C,A,B,object.blog

(<class '__main__.C'>, <class '__main__.A'>, <class '__main__.B'>, <class 'object'>)name is wangname is xiaoming

当咱们把A类中的注释去掉后,执行代码输出:能够看到,当A执行后继续执行了B中的name()函数。若是B中仍然有super函数则会继续向上去查找object中是否有name()函数。继承

(<class '__main__.C'>, <class '__main__.A'>, <class '__main__.B'>, <class 'object'>)name is wangname is xiaomingname is cat

关注公众号:「Python专栏」,后台回复「腾讯架构资源1」,获取由腾讯架构师整理的大数据学习资源包全套!!!资源

Python专栏二维码

相关文章
相关标签/搜索