如果在子类中也定义了_init_()函数,那么该如何调用基类的_init_()函数:
方法一、明确指定 :
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() # wrong
class 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 没有规定代码必须怎样去写,但是养成一些好的习惯是很重要,会避免很多你不了解的问题发生。