最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

关于python类中super()和__init__()的区别说明

来源:懂视网 责编:小采 时间:2020-11-27 14:25:33
文档

关于python类中super()和__init__()的区别说明

关于python类中super()和__init__()的区别说明:单继承时super()和init()实现的功能是类似的class Base(object): def init(self): print 'Base create' class childA(Base): def init(self): print 'creat A ', Base.init(self) clas
推荐度:
导读关于python类中super()和__init__()的区别说明:单继承时super()和init()实现的功能是类似的class Base(object): def init(self): print 'Base create' class childA(Base): def init(self): print 'creat A ', Base.init(self) clas

单继承时super()和init()实现的功能是类似的

class Base(object):
 def init(self):
 print 'Base create'
class childA(Base):
 def init(self):
 print 'creat A ',
 Base.init(self)
class childB(Base):
 def init(self):
 print 'creat B ',
 super(childB, self).init()
base = Base()
a = childA()
b = childB()

输出结果:

Base create
creat A Base create
creat B Base create

区别是使用super()继承时不用显式引用基类。

super()只能用于新式类中

把基类改为旧式类,即不继承任何基类

class Base():
 def init(self):
 print 'Base create'

执行时,在初始化b时就会报错:

super(childB, self).init()
TypeError: must be type, not classobj

super不是父类,而是继承顺序的下一个类

在多重继承时会涉及继承顺序,super()相当于返回继承顺序的下一个类,而不是父类,类似于这样的功能:

def super(class_name, self):
 mro = self.class.mro()
 return mro[mro.index(class_name) + 1]

mro()用来获得类的继承顺序。 例如:

class Base(object):
 def init(self):
 print 'Base create'
class childA(Base):
 def init(self):
 print 'enter A '
 # Base.init(self)
 super(childA, self).init()
 print 'leave A'
class childB(Base):
 def init(self):
 print 'enter B '
 # Base.init(self)
 super(childB, self).init()
 print 'leave B'
class childC(childA, childB):
 pass
c = childC()
print c.class.mro

输出结果如下:

enter A 
enter B 
Base create
leave B
leave A
(<class 'main.childC'>, <class 'main.childA'>, <class 'main.childB'>, <class 'main.Base'>, <type 'object'>)

supder和父类没有关联,因此执行顺序是A —> B—>—>Base

执行过程相当于:初始化childC()时,先会去调用childA的构造方法中的 super(childA, self).init(), super(childA, self)返回当前类的继承顺序中childA后的一个类childB;然后再执行childB().init(),这样顺序执行下去。

在多重继承里,如果把childA()中的 super(childA, self).init() 换成Base._init_(self),在执行时,继承childA后就会直接跳到Base类里,而略过了childB:

enter A 
Base create
leave A
(<class 'main.childC'>, <class 'main.childA'>, <class 'main.childB'>, <class 'main.Base'>, <type 'object'>)

从super()方法可以看出,super()的第一个参数可以是继承链中任意一个类的名字,

如果是本身就会依次继承下一个类;

如果是继承链里之前的类便会无限递归下去;

如果是继承链里之后的类便会忽略继承链汇总本身和传入类之间的类;

比如将childA()中的super改为:super(childC, self).init(),程序就会无限递归下去。 如:

 File "test.py", line 12, in init
 super(childC, self).init()
 File "test.py", line 12, in init
 super(childC, self).init()
 File "test.py", line 12, in init
 super(childC, self).init()
 File "test.py", line 12, in init
 super(childC, self).init()
 File "test.py", line 12, in init
 super(childC, self).init()
 File "test.py", line 12, in init
 super(childC, self).init()
 File "test.py", line 12, in init
 super(childC, self).init()
 File "test.py", line 12, in init
 super(childC, self).init()
 File "test.py", line 12, in init
 super(childC, self).init()
RuntimeError: maximum recursion depth exceeded while calling a Python object

super()可以避免重复调用

如果childA基础Base, childB继承childA和Base,如果childB需要调用Base的init()方法时,就会导致init()被执行两次:

class Base(object):
 def init(self):
 print 'Base create'
class childA(Base):
 def init(self):
 print 'enter A '
 Base.init(self)
 print 'leave A'
class childB(childA, Base):
 def init(self):
 childA.init(self)
 Base.init(self)
b = childB()

Base的init()方法被执行了两次

enter A 
Base create
leave A
Base create

使用super()是可避免重复调用

class Base(object):
 def init(self):
 print 'Base create'
class childA(Base):
 def init(self):
 print 'enter A '
 super(childA, self).init()
 print 'leave A'
class childB(childA, Base):
 def init(self):
 super(childB, self).init()
b = childB()
print b.class.mro()
enter A 
Base create
leave A
[<class 'main.childB'>, <class 'main.childA'>, <class 'main.Base'>, <type 'object'>]

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

关于python类中super()和__init__()的区别说明

关于python类中super()和__init__()的区别说明:单继承时super()和init()实现的功能是类似的class Base(object): def init(self): print 'Base create' class childA(Base): def init(self): print 'creat A ', Base.init(self) clas
推荐度:
标签: 中的 区别 python
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top