Python继承的核心是子类自动获得父类属性和方法以避免重复代码,关键在于自然、可维护的设计:一、基础继承通过class子类(父类):实现;二、重写方法支持多态;三、子类__init__需调用super().__init__()确保初始化完整;四、实际应用中通过分层抽象(如DataLoader及其子类)实现高复用与易扩展。

Python继承的核心是让子类自动获得父类的属性和方法,从而避免重复写代码。关键不在于“能不能用”,而在于“怎么设计才自然、可维护”。
一、基础继承:用 class 子类(父类): 建立关系
子类定义时在括号里写父类名,就自动继承其所有公开属性和方法。不需要额外声明或导入。
- 父类方法在子类中直接可用,比如 dog.bark() 调用的是父类 Animal 定义的 bark 方法
- 子类可以定义自己独有的方法,不影响父类逻辑
- 子类能访问父类的实例属性(如 self.name),只要父类在 __init__ 中赋值且未设为私有(即非双下划线开头)
二、重写方法:用同名方法覆盖父类行为
当子类需要不同逻辑时,直接定义同名方法即可。Python 运行时会优先调用子类版本,这是多态的基础。
- 例如父类的 make_sound() 返回 "Animal sound",狗类重写后返回 "Woof!"
- 如果还想复用父类逻辑,可在子类方法中用 super().make_sound() 显式调用
- 注意:重写不是删除父类方法,只是调用路径变了;父类对象仍按原逻辑运行
三、扩展初始化:子类 __init__ 中调用 super().__init__()
父类的初始化逻辑(比如设置 name、age)不能被跳过,否则子类实例可能缺少必要属性。
立即学习“Python免费学习笔记(深入)”;
- 子类 __init__ 第一行通常写 super().__init__(name, age),把共用参数传给父类处理
- 再在后面添加子类特有属性,比如 self.breed = breed
- 漏掉 super() 是新手常见错误,会导致 AttributeError:'Dog' object has no attribute 'name'
四、实际复用场景:从通用到具体逐层抽象
真正体现继承价值的,是建模真实业务时的分层设计。比如处理不同格式的数据文件:
- 定义基类 DataLoader:含通用方法 load()、validate()
- 子类 CSVLoader 重写 load(),用 csv 模块解析;JSONLoader 用 json.load()
- 所有子类自动拥有 validate(),无需每处重复校验逻辑
- 后续加 XMLLoader 或数据库 Loader,只需关注差异部分,主干逻辑零改动
不复杂但容易忽略:继承不是为了“看起来高级”,而是让变化集中、扩展简单。写代码前先问一句——这个功能是所有子类都该有的吗?如果是,就放进父类;如果只属于某一种,就留在子类里。










