Python中super()函数是如何实现多继承的?

2026-05-24 18:071阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计708个文字,预计阅读时间需要3分钟。

Python中super()函数是如何实现多继承的?

前言:super()函数用于调用父类(超类)的一个方法。

super()函数是用来解决多重继承时方法调用的顺序问题的。直接使用类名调用父类方法,在单继承时没有问题,但在多重继承时可能会出现顺序混乱的问题。通过使用super()函数,可以直接使用父类名来调用父类的方法,从而保证方法调用的正确顺序。

前言

super()函数是用于调用父类(超类)的一个方法。

super()是用来解决多重继承问题的,直接用类名调用父类方法在使用单继承的时候没问题,但是如果使用多继承,会涉及到查找顺序(MRO)、重复调用(钻石继承)等种种问题。

Python中super()函数是如何实现多继承的?

语法

super(type[, object-or-type])

参数:

type:类

object-or-type:类,一般是 self。

Python3.x 和 Python2.x 的区别

Python 3 可以使用直接使用 super().xxx代替 super(Class, self).xxx :

Python3.x 实例:

class A:
def add(self, x):
y = x+1
print(y)
class B(A):
def add(self, x):
super().add(x)
b = B()
b.add(2) # 3

Python2.x 实例:

#!/usr/bin/python
# -*- coding: UTF-8 -*-

class A(object): # Python2.x 记得继承 object
def add(self, x):
y = x+1
print(y)
class B(A):
def add(self, x):
super(B, self).add(x)
b = B()
b.add(2) # 3

python中super().__init__()

简单的说super().init(),就是继承父类的init方法,同样可以使用super()去继承其他方法。

1、从实例中对比(python3)

1.1、实例

1.2、运行结果与对比

1.3、完整代码

2、关于继承顺序

最底层:先写一个父类A

class A:
def __init__(self):
print('A')

第二层:让 B、C、D 继承自A

class B(A):
def __init__(self):
print('B')
super().__init__()

class C(A):
def __init__(self):
print('C')
super().__init__()

class D(A):
def __init__(self):
print('D')
super().__init__()

第三层: E、F、G 继承自B、C、D

class E(B, C):
def __init__(self):
print('E')
super().__init__()

class F(C, D):
def __init__(self):
print('F')
super().__init__()

class G(E, F):
def __init__(self):
print('G')
super().__init__()

看看G的继承顺序:

我们发现G继承自E, F是并列的,初始化的时候不会先把E初始化完毕才初始化F。

去期待陌生,去拥抱惊喜。

本文共计708个文字,预计阅读时间需要3分钟。

Python中super()函数是如何实现多继承的?

前言:super()函数用于调用父类(超类)的一个方法。

super()函数是用来解决多重继承时方法调用的顺序问题的。直接使用类名调用父类方法,在单继承时没有问题,但在多重继承时可能会出现顺序混乱的问题。通过使用super()函数,可以直接使用父类名来调用父类的方法,从而保证方法调用的正确顺序。

前言

super()函数是用于调用父类(超类)的一个方法。

super()是用来解决多重继承问题的,直接用类名调用父类方法在使用单继承的时候没问题,但是如果使用多继承,会涉及到查找顺序(MRO)、重复调用(钻石继承)等种种问题。

Python中super()函数是如何实现多继承的?

语法

super(type[, object-or-type])

参数:

type:类

object-or-type:类,一般是 self。

Python3.x 和 Python2.x 的区别

Python 3 可以使用直接使用 super().xxx代替 super(Class, self).xxx :

Python3.x 实例:

class A:
def add(self, x):
y = x+1
print(y)
class B(A):
def add(self, x):
super().add(x)
b = B()
b.add(2) # 3

Python2.x 实例:

#!/usr/bin/python
# -*- coding: UTF-8 -*-

class A(object): # Python2.x 记得继承 object
def add(self, x):
y = x+1
print(y)
class B(A):
def add(self, x):
super(B, self).add(x)
b = B()
b.add(2) # 3

python中super().__init__()

简单的说super().init(),就是继承父类的init方法,同样可以使用super()去继承其他方法。

1、从实例中对比(python3)

1.1、实例

1.2、运行结果与对比

1.3、完整代码

2、关于继承顺序

最底层:先写一个父类A

class A:
def __init__(self):
print('A')

第二层:让 B、C、D 继承自A

class B(A):
def __init__(self):
print('B')
super().__init__()

class C(A):
def __init__(self):
print('C')
super().__init__()

class D(A):
def __init__(self):
print('D')
super().__init__()

第三层: E、F、G 继承自B、C、D

class E(B, C):
def __init__(self):
print('E')
super().__init__()

class F(C, D):
def __init__(self):
print('F')
super().__init__()

class G(E, F):
def __init__(self):
print('G')
super().__init__()

看看G的继承顺序:

我们发现G继承自E, F是并列的,初始化的时候不会先把E初始化完毕才初始化F。

去期待陌生,去拥抱惊喜。