pythonsuper用法_怎么使用python中super()方法?

想必大家在编写代码,尤其是类的集成,会经常使用super这个方法吧,因此这个方法作用非常大,具体要怎么去利用呢?一起来看下吧~

为什么要用super?

1、让代码维护更加简单

Python是一门面向对象的语言,定义类时经常用到继承的概念,既然用到继承就少不得要在子类中引用父类的属性,我们可以通过“父类名.属性名”的方式来调用,代码如下:class A:

def fun(self):

print('A.fun')

class B(A):

def fun(self):

A.fun(self)

print('B.fun')

一旦A类类名改了,我们就要分别到那几十上百个子类中修改,不但要改继承时用到的A类名,调用A类方法时用到的A类名也要改,繁琐的很,用super就好多了:class A:

def fun(self):

print('A.fun')

class B(A):

def fun(self):

super().fun()

print('B.fun')

2、解决多继承带来的重复调用(菱形继承)、查找顺序(MRO)问题

Python是的继承机制是多继承,还是用这种方法来调用父类属性就会就回带来许多问题。假如有A、B、C、D这4个类,继承关系如下,我们要在各子类方法中显式调用父类的方法(姑且不考虑是否符合需求):

1604025235882493.png

用“父类名.属性名” 的方式调用,代码如下:class A:

def fun(self):

print('A.fun')

class B(A):

def fun(self):

A.fun(self)

print('B.fun')

class C(A):

def fun(self):

A.fun(self)

print('C.fun')

class D(B , C):

def fun(self):

B.fun(self)

C.fun(self)

print('D.fun')

D().fun()

输出结果为:A.fun

B.fun

A.fun

C.fun

D.fun

A类被实例化了两次。这就是多继承带来的重复调用(菱形继承)的问题。使用super可以很好的解决这一问题:class A:

def fun(self):

print('A.fun')

class B(A):

def fun(self):

super(B , self).fun()

print('B.fun')

class C(A):

def fun(self):

super(C , self).fun()

print('C.fun')

class D(B , C):

def fun(self):

super(D , self).fun()

print('D.fun')

D().fun()

输出结果如下:A.fun

C.fun

B.fun

D.fun

怎么用super?

super是一个类(不是方法),实例化之后得到的是一个代理的对象,而不是得到了父类,并且我们使用这个代理对象来调用父类或者兄弟类的方法。使用格式如下:super([type[, object-or-type]])

将这个格式展开来就有一下几种传参方式:super()

super(type , obj)

super(type_1 , type_2)

注意:可没有super(type)这种方式

因此大家了解为什么要用super方法,以及怎么用super方法了嘛?如需了解更多python实用知识,点击进入PyThon学习网教学中心。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值