Python 在子类中调用父类方法详解(单继承、多层继承、多重继承)

简介: Python 在子类中调用父类方法详解(单继承、多层继承、多重继承)

Python在子类中调用父类方法详解(单继承、多层继承、多重继承)

 


 

 

测试环境:

win7 64

Python版本:Python 3.3.5

 

 

代码实践:

1、在子类中通过“类名”调用父类的方法

class FatherA:

   def __init__(self):

       print('init action in father class A')

 

class SubClassB(FatherA):

   def __init__(self):

       print('init action in subclass B')

       FatherA.__init__(self) #在子类中调用父类的方法:父类名.方法名称(参数)

 

if __name__ == '__main__':

   b = SubClassB()

 

运行结果:

>>> ================================ RESTART ================================

>>>

init action in subclass B

init action in father class A

 

缺点:当一个子类的父类发生变化时(如类SubClassB的父类由FatherA变为FatherD时),必须遍历整个类定义,把子类中所有的父类类名全部替换过来

 

2、在子类中通过“super”方法调用父类的方法

场景1、单层继承

class FatherA:

   def __init__(self):

       print('init action in father class A')

 

class SubClassB(FatherA):

   def __init__(self):

       print('init action in father class B')

       super().__init__() #在子类中调用父类的方法:super().方法名称(参数)

 

if __name__ == '__main__':

   b = SubClassB()

 

 

class FatherA:

   def __init__(self):

       print('init action in father class A')

 

class SubClassB(FatherA):

   def __init__(self):

       print('init action in subclass B')

       super(SubClassB, self).__init__()  #在子类中调用父类的方法:super(type, obj).方法名称(参数)

 

     

if __name__ == '__main__':

   b = SubClassB()

 

运行结果:

>>> ================================ RESTART ================================

>>>

init action in father class B

init action in father class A

说明:

1super(type, obj),其中obj必须是type类型、type子类类型的实例,否则会报错:

TypeError: super(type, obj): obj must be an instance or subtype of type

 

2super().__init__() 效果等同super(SubClassB, self). __init__()

 

场景2、多层继承

实验1

class FatherA:

   def __init__(self):

       print('init action in father class A')

 

class SubClassB(FatherA):

   def __init__(self):

       print('init action in subclass B')

       super().__init__()

 

class SubClassC(SubClassB):

   def __init__(self):

       print('init action in subclass C')

       super().__init__()

 

if __name__ == '__main__':

   b = SubClassC()

 

运行结果:

>>> ================================ RESTART ================================

>>>

init action in subclass C

init action in subclass B

init action in father class A

 

对比实验1-1

class FatherA:

   def __init__(self):

       print('init action in father class A')

 

class SubClassB(FatherA):

   def __init__(self):

       print('init action in subclass B')

       super().__init__()

 

class SubClassC(SubClassB):

   def __init__(self):

       print('init action in subclass C')

       super(SubClassB, self).__init__()

 

 

if __name__ == '__main__':

   b = SubClassC()

 

运行结果:

>>> ================================ RESTART ================================

>>>

init action in subclass C

init action in father class A

>>>

 

对比实验1-2

class FatherA:

   def __init__(self):

       print('init action in father class A')

 

class SubClassB(FatherA):

   def __init__(self):

       print('init action in subclass B')

       super().__init__()

 

class SubClassC(SubClassB):

   def __init__(self):

       print('init action in subclass C')

       super(FatherA, FatherA).__init__(self) #在子类中调用父类的方法:super(type, type).方法名称(参数)

 

 

if __name__ == '__main__':

   b = SubClassC()

 

说明:可把super(FatherA, FatherA).__init__(self)换成:

super(FatherA, self).__init__()  

super(FatherA, SubClassB).__init__(self)

super(FatherA, SubClassC).__init__(self)

 

注意:以上这种情况,必须给__init__传递参数self,否则会报错:

TypeError: __init__() missing 1 required positional argument: 'self'

 

运行结果:

>>> ================================ RESTART ================================

>>>

init action in subclass C

>>>

说明:super(type1, type2)type2必须和type1相同类型,或者其子类类型

 

实验2

class FatherA:

   def __init__(self):

       print('init action in father class A')

 

class SubClassB(FatherA):

   def __init__(self):

       print('init action in subclass B')

       super().__init__()

 

class SubClassC(SubClassB):

   def __init__(self):

       print('init action in subclass C')

       super().__init__()

 

class SubClassD(SubClassC):

   def __init__(self):

       print('init action in subclass D')

       super().__init__()

 

if __name__ == '__main__':

   b = SubClassD()

 

运行结果:

>>> ================================ RESTART ================================

>>>

init action in subclass D

init action in subclass C

init action in subclass B

init action in father class A

 

对比实验2-1

class FatherA:

   def __init__(self):

       print('init action in father class A')

 

class SubClassB(FatherA):

   def __init__(self):

       print('init action in subclass B')

       super().__init__()

 

class SubClassC(SubClassB):

   def __init__(self):

       print('init action in subclass C')

       super().__init__()

 

class SubClassD(SubClassC):

   def __init__(self):

       print('init action in subclass D')

       super(SubClassB, self).__init__()

 

if __name__ == '__main__':

   b = SubClassD()

 

运行结果:

>>> ================================ RESTART ================================

>>>

init action in subclass D

init action in father class A

>>>

 

对比实验2-2

class FatherA:

   def __init__(self):

       print('init action in father class A')

 

class SubClassB(FatherA):

   def __init__(self):

       print('init action in subclass B')

       super().__init__()

 

class SubClassC(SubClassB):

   def __init__(self):

       print('init action in subclass C')

       super().__init__()

 

class SubClassD(SubClassC):

   def __init__(self):

       print('init action in subclass D')

       super(SubClassC, self).__init__()

 

if __name__ == '__main__':

   b = SubClassD()

 

运行结果:

>>> ================================ RESTART ================================

>>>

init action in subclass D

init action in subclass B

init action in father class A

 

通过对比实验2-12-2,可看出super(type[,type2_or_obj]),type决定了super调用方法所在的父类--type的父类(如果有的话),即type决定了前往哪个父类调用指定的方法

 

目录
相关文章
|
2月前
|
机器学习/深度学习 Python
堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能
本文深入探讨了堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能。文章详细介绍了堆叠的实现步骤,包括数据准备、基础模型训练、新训练集构建及元学习器训练,并讨论了其优缺点。
80 3
|
26天前
|
算法 Python
Python多继承时子类如何调用指定父类
通过本文的介绍,希望您能够深入理解Python多继承时子类如何调用指定父类的方法,并在实际项目中灵活运用这些技巧,编写出高效且易维护的代码。
28 11
|
29天前
|
安全
Python-打印99乘法表的两种方法
本文详细介绍了两种实现99乘法表的方法:使用`while`循环和`for`循环。每种方法都包括了步骤解析、代码演示及优缺点分析。文章旨在帮助编程初学者理解和掌握循环结构的应用,内容通俗易懂,适合编程新手阅读。博主表示欢迎读者反馈,共同进步。
|
25天前
|
算法 Python
Python多继承时子类如何调用指定父类
通过本文的介绍,希望您能够深入理解Python多继承时子类如何调用指定父类的方法,并在实际项目中灵活运用这些技巧,编写出高效且易维护的代码。
36 1
|
1月前
|
JSON 安全 API
Python调用API接口的方法
Python调用API接口的方法
212 5
多重继承 | Python从入门到精通:高阶篇之三十二
在Python中是支持多重继承的,也就是我们可以为一个类同时指定多个父类。这是与别的大部分语言不一致的。但在开发中没有特殊的情况,应该尽量避免使用多重继承,因为多重继承会让我们的代码过于复杂。
多重继承 | Python从入门到精通:高阶篇之三十二
|
1月前
|
人工智能 数据可视化 数据挖掘
探索Python编程:从基础到高级
在这篇文章中,我们将一起深入探索Python编程的世界。无论你是初学者还是有经验的程序员,都可以从中获得新的知识和技能。我们将从Python的基础语法开始,然后逐步过渡到更复杂的主题,如面向对象编程、异常处理和模块使用。最后,我们将通过一些实际的代码示例,来展示如何应用这些知识解决实际问题。让我们一起开启Python编程的旅程吧!
|
1月前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
21天前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
105 80
|
10天前
|
Python
[oeasy]python055_python编程_容易出现的问题_函数名的重新赋值_print_int
本文介绍了Python编程中容易出现的问题,特别是函数名、类名和模块名的重新赋值。通过具体示例展示了将内建函数(如`print`、`int`、`max`)或模块名(如`os`)重新赋值为其他类型后,会导致原有功能失效。例如,将`print`赋值为整数后,无法再用其输出内容;将`int`赋值为整数后,无法再进行类型转换。重新赋值后,这些名称失去了原有的功能,可能导致程序错误。总结指出,已有的函数名、类名和模块名不适合覆盖赋新值,否则会失去原有功能。如果需要使用类似的变量名,建议采用其他命名方式以避免冲突。
30 14