飘逸的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。不然可能导致没被调用或者被调用多次。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值