飘逸的python - super()只不过是用来避免硬编码的

当在子类需要调用父类的方法时,在python2.2之前,直接用类名调用类的方法,即非绑定的类方法,并把自身对象self作参数传进去。

class A(object):
    def say(self):
        print 'I am A'

class B(A):
    def say(self):
        print 'I am B'
        A.say(self)

b = B()
b.say()

输出
I am B
I am A

这样运作挺好,不过有个问题,当父类改了名字时,就要把这些显式调用父类的一个个更正,子类和父类耦合比较高。
于是python2.2后就推出了super()方法来避免硬编码,不用关心父类名叫什么。
使用super()方法,上面的代码可以写成如下。

class B(A):
    def say(self):
        print 'I am B'
        super(B,self).say()

python3.0后,又做了改良,super()方法不用传参数,即上面的那行代码直接super().say()就行了。

需要注意的问题:

  • super只能用在新式类中,关于新式类和旧式类我会在后面的博文中提及。
  • super在多重继承有问题,如果子类继承多个父类,那么super调用第一个父类的方法
  • 不要混用这两种调用父类方法的方案,要么都用非绑定的类方法,要么都用super。不然可能导致没被调用或者被调用多次。

你可能感兴趣的:(Python)