Python中的super用法

时间:2024-11-11 07:37:02

如果在子类中也定义了_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()
()

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