本文实例讲述了Python实现带参数与不带参数的多重继承。分享给大家供大家参考,具体如下:
1. 不带参数的多重继承
# 作者:hhh5460 # 时间:2017.07.18 class A(object): def show_x(self): print('A') class B(object): def show_y(self): print('B') class C(object): def show_z(self): print('C') class D(A, B, C): pass # 测试 if __name__ == '__main__': d = D() d.show_x() # A d.show_y() # B d.show_z() # C
2. 带参数的多重继承
# 作者:hhh5460 # 时间:2017.07.18 class A(object): def __init__(self, x=0): self._x = x def show_x(self): print(self._x) def show_name(self): print('A') class B(object): def __init__(self, y=0): self._y = y def show_y(self): print(self._y) def show_name(self): print('B') class C(object): def __init__(self, z=0): self._z = z def show_z(self): print(self._z) def show_name(self): print('C') # 注意下面两类D、E,都是继承A、B、C,且A类的优先级最高。但是三条__init__语句的顺序是相反的 class D(A, B, C): def __init__(self, x=0, y=0, z=0): C.__init__(self, z) # init C B.__init__(self, y) # init B A.__init__(self, x) # init A (A最优先) class E(A, B, C): def __init__(self, x=0, y=0, z=0): super(E, self).__init__(x) # init A (A最优先) # 此句可简写成:super().__init__(x) super(A, self).__init__(y) # init B super(B, self).__init__(z) # init C # 测试 if __name__ == '__main__': d = D(1,2,3) d.show_x() # 1 d.show_y() # 2 d.show_z() # 3 d.show_name() # A e = E(1,2,3) e.show_x() # 1 e.show_y() # 2 e.show_z() # 3 e.show_name() # A
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python面向对象程序设计入门与进阶教程》、《Python数据结构与算法教程》、《Python Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python编码操作技巧总结》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。