Python中的super()简单用法

 2023-09-15 阅读 20 评论 0

摘要:如果在子类中也定义了_init_()函数,那么该如何调用基类的_init_()函数: python中super、方法一、明确指定: class C(P):def __init__(self):P.__init__(self)print 'calling Cs construtor' 方法二、使用super()方法: class C(P):def __i

如果在子类中也定义了_init_()函数,那么该如何调用基类的_init_()函数:

python中super、方法一、明确指定 :

class  C(P):def __init__(self):P.__init__(self)print 'calling Cs construtor'


方法二、使用super()方法 :

class  C(P):def __init__(self):super(C,self).__init__()print 'calling Cs construtor'c=C()


Python中的super()方法设计目的是用来解决多重继承时父类的查找问题,所以在单重继承中用不用 super 都没关系;但是,使用 super() 是一个好的习惯。一般我们在子类中需要调用父类的方法时才会这么用。

super()的好处就是可以避免直接使用父类的名字.主要用于多重继承,如下:

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


这样做的好处就是:如果你要改变子类继承的父类(由A改为B),你只需要修改一行代码(class C(A): -> class C(B))即可,而不需要在class C的大量代码中去查找、修改基类名,另外一方面代码的可移植性和重用性也更高。

另外:避免使用 super(self.__class__, self),一般情况下是没问题的,就是怕极端的情况:

class Foo(object):def x(self):print 'Foo'class Foo2(Foo):def x(self):print 'Foo2'super(self.__class__, self).x() # wrongclass Foo3(Foo2):def x(self):print 'Foo3'super(Foo3, self).x()f = Foo3()
f.x()


在 Foo2 中的 super(self.__class__, self) 导致了死循环,super 永远去找 Foo3 的 MRO 中的下一个类,super 的第一个参数应该总是当前的类,Python 没有规定代码必须怎样去写,但是养成一些好的习惯是很重要,会避免很多你不了解的问题发生。

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/1/61086.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息