python super().__init__的用法
载自 :(85条消息) python super().__init__的用法详解_一条水里的鱼的博客-CSDN博客_super.__init__
用于学习记录
一、前言
super(father).__init__()
目的:调用父类的__init__()函数进行初始化
二、应用场景:
class A(): def __init__(self): self.a=100 self.b='xxx' self.c=True def func1(self): pass
如上,有类A,现在想创建类B继承类A,但是类B的self.c需要改为False,super(子类,self).__init__() 可以发挥作用了
class B(A): def __init__(self): super(B,self).__init__() self.c=True def func2(self): print(self.b) print(self.c) b=B() b.func2() 输出: xxx True
问题:super调用父类的init方法进行初始化,那当父类的init方法中有调用方法时,则这时候是调用父类的还是调用子类的呢(当然前提是子类有重写父类的方法)?
三、进阶理解
class A(): def __init__(self,a,b): self.a=a self.b=b print(self.b) self.prints() def prints(self): print('self.A:',self.a) class Zilei(A): def __init__(self,a): super(Zilei, self).__init__(a,a+1) self.a = a+100 print('self.a:', self.a) def prints(self): print('self.b:',self.b) ass=Zilei(1) # 1/ 先执行super(Zilei, self).__init__(a,a+1),即执行A.__init__ # 所以输出print(self.b),即2 # 再执行self.prints() ,值得注意的是A.prints(),在子类zilei被重写,所以应该执行的是zilei.prints(),即输出:self.b:2 #2/返回到zilei.__init__执行print('self.a:', self.a) 输出 self.a:101 # 最终输出的结果: # 2 # self.b:2 # self.a:101
看完上述分析,答案很明显是:调用子类重写后的方法