002.python 多继承调用指定父类同名方法的方法

       如果子类和继承了多个父类,并且这些父类中有多个方法的方法名一样时,我该如何调用指定父类中的同名方法呢?不妨先举一个小例子:

class A:
    def f_a(self):
        print('--------A--------')
class B:
    def f_a(self):
        print('-------B-------')
class C(A,B):
    def f_a(self):
        print('--------C--------')
c = C()
c.f_a()
>>> --------C--------

       如果我们想在C类中的f_a方法里面使用父类A或者父类B的方法该如何操作呢?

方法有两种:

方法一:把对象调用转换为类调用:

class C(A,B):
    def f_a(self):
        A.f_a(self)
        B.f_a(self)
        print('--------C--------')
c = C()
c.f_a()

输出结果为:

>>>--------A--------
>>>--------B--------
>>>--------C--------

       这里调用父类的f_a方法时括号里面要写self,表明这是一个类调用,但这种方法有一个缺点,比如说如果修改了父类的名称,那么在子类中会涉及多出修改,并且python是允许多继承的语言,上述方法在多继承时就要重复写多次,显得累赘,为了解决这些问题,python引进了super()机制,接下来想必大家都猜到了下一种调用父类的另一种方法了吧。

方法二:使用super()机制,引入super()方法:

class C(A,B):
    def f_a(self):
        super().f_a()
        print('--------C--------')
c = C()
c.f_a()
>>>--------A--------
>>>--------C--------

       这里直接使用super()方法会调用A类的f_a方法,因为它会默认多继承中从左到右的顺序来调用,那么有人就会问了,假如我想调用B类中的f_a方法是不是把A和B对调下呢,这种方法也行,不过这不算的上是一种较为巧妙的方法。
       我们还可以使用super()方法,但要对其修改下:

class C(A,B):
    def f_a(self):
        super(C,self).f_a()
        super(A,self).f_a()
        print('--------C--------')
c = C()
c.f_a()
>>>--------A--------
>>>--------B--------
>>>--------C--------

       看到没,这样写:super(C,self).f_a()会调用最左边的(即A类)的f_a方法,而super(A,self).f_a()会调用A类后面那个类的f_a()方法,若果继承的不止两个类,如果要调用某个类方法,只要知道前一个类名就可以调用。

       下面给出一个例子,请读者自行思考运行结果:

class Point(object):

    def __init__(self,x,y):

        self.x = x
        self.y = y

    def string(self):
        print("X:{0},Y:{1}".format(self.x,self.y))


# class Circle(Point):
#
#     def __init__(self,x,y,radius):
#         super().__init__(x,y)
#         self.radius = radius
#
#     def string(self):
#         print("该图形初始化点为:({0},{1}),半径为:{2}。".format(self.x,self.y,self.radius))


class Size:

    def __init__(self,width,heigth):
        self.width = width
        self.height = heigth

    def string(self):
        print("Width:{0},Height:{1}".format(self.width,self.height))


class Rectangle(Point,Size):

    def __init__(self,x,y,width,height):

        super(Rectangle,self).__init__(x,y)
        super(Point,self).__init__(width,height)
        #这里值得注意的是,如果要跨过一个父类去另外一个父类调用同名方法时
        #应当在super()的参数中指定要继承的类在继承顺序中的前一个类的名称
        #如果没有就把这个名称写成自己的类名


    def string(self):

        print("该图形的初始化点为({0},{1}),长宽分别为Height:{2},Width:{3}".format(self.x,self.y,self.height,self.width))



if __name__ == '__main__':
    # c = Circle(0,0,100)
    # c.string()

    r = Rectangle(0,0,100,100)
    r.string()
  • 5
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值