EADST

Python 继承总结:父类与子类的调用关系

在 Python 面向对象编程中,继承 (Inheritance) 是一个核心机制。通过继承,子类可以复用父类的属性和方法,并在需要时覆盖或扩展它们。

本文用几个小例子来梳理:


1. 基本继承

class Parent:
    def hello(self):
        print("Hello from Parent")

class Child(Parent):
    pass

c = Child()
c.hello()   # 输出: Hello from Parent

👉 子类 Child 没有实现 hello 方法,因此调用时会沿着 MRO(方法解析顺序) 去父类找。


2. 方法重写(覆盖)

class Parent:
    def hello(self):
        print("Hello from Parent")

class Child(Parent):
    def hello(self):
        print("Hello from Child")

c = Child()
c.hello()   # 输出: Hello from Child

👉 子类里定义了同名方法,父类的方法就被覆盖(Override)。


3. 使用 super() 调用父类方法

有时希望子类在重写方法的同时,保留父类逻辑

class Parent:
    def hello(self):
        print("Hello from Parent")

class Child(Parent):
    def hello(self):
        super().hello()   # 调用父类方法
        print("Hello from Child")

c = Child()
c.hello()

输出:

Hello from Parent
Hello from Child

4. 父类 __call__ 调用子类方法

一个常见设计是父类在 __call__ 中固定调用几个“步骤方法”,子类只需重写步骤:

class Base:
    def __call__(self, data):
        data = self.step1(data)
        data = self.step2(data)
        return data

    def step1(self, data):
        return data + " base_step1 "

    def step2(self, data):
        return data + " base_step2 "

class Child(Base):
    def step2(self, data):
        return data + " child_step2 "

c = Child()
print(c("input"))

输出:

input base_step1  child_step2 

👉 父类 __call__ 会自动调用子类重写的 step2,这是 动态绑定 的体现。


5. 子类完全自定义 __call__

如果子类自己定义了 __call__,就会 覆盖掉父类的 __call__

class Base:
    def __call__(self, data):
        return self.process(data)

    def process(self, data):
        return data + " base "

class Child(Base):
    def __call__(self, data):
        return data + " child "

c = Child()
print(c("input"))

输出:

input child 

👉 父类的 __call__ 完全被替代,不会再执行。


6. 总结规律

  • 继承默认走父类 → 子类没实现的方法会去父类找。
  • 方法名相同 → 子类方法覆盖父类。
  • 父类内部调用子类方法 → Python 的动态绑定机制决定了:即使在父类中写 self.xxx(),只要子类实现了 xxx,就会调用子类的。
  • 子类定义 __call__ → 会完全替代父类 __call__ 的执行逻辑,除非显式 super().__call__()

✅ 记住一个口诀:

父类搭骨架,子类来填肉。 父类提供通用流程,子类通过覆盖方法来定制行为。

相关标签
About Me
XD
Goals determine what you are going to be.
Category
标签云
Interview YOLO Hilton CSV Input Jetson VPN AI COCO ONNX 阿里云 GPTQ FastAPI Breakpoint Pillow scipy Gemma DeepStream diffusers Video SQLite Translation Ubuntu Datetime Michelin Heatmap Crawler C++ Pytorch tqdm 报税 GIT Food UI Linux CUDA Base64 Distillation Paddle Pickle transformers Baidu Image2Text Streamlit Proxy Color HaggingFace Excel 公式 Clash Template WAN Attention Bipartite FP8 OpenCV Tiktoken Use SAM SQL LLAMA 算法题 Transformers JSON HuggingFace NLTK torchinfo Domain 多线程 TensorFlow Web Statistics LLM DeepSeek Plotly Tracking Numpy Land CEIR logger CLAP QWEN Algorithm Diagram Math Llama FlashAttention Review Git Firewall Data PyTorch 域名 IndexTTS2 多进程 Shortcut CTC LaTeX Qwen2 CAM hf Nginx Anaconda RAR Paper PIP SPIE llama.cpp uWSGI TTS XML Random Freesound GPT4 版权 BTC Quantization Augmentation XGBoost Vmess 净利润 PyCharm ModelScope FP32 Windows Logo 音频 RGB Github Sklearn BeautifulSoup NLP CV 财报 git git-lfs Magnet v2ray Quantize Markdown Hungarian VGG-16 腾讯云 Knowledge VSCode Pandas TensorRT PDB Conda printf Safetensors 关于博主 FP64 Plate LeetCode ChatGPT LoRA uwsgi Mixtral UNIX Password Jupyter Bin 签证 Claude API Google EXCEL Disk OpenAI Qwen InvalidArgumentError Bert FP16 SVR ResNet-50 v0.dev Vim Animate Cloudreve CC 飞书 Tensor TSV PDF NameSilo OCR Ptyhon Permission tar Hotel 证件照 mmap GoogLeNet Zip Qwen2.5 继承 Card Python 搞笑 Dataset Django MD5 GGML Miniforge Docker WebCrawler Website BF16 Bitcoin
站点统计

本站现有博文311篇,共被浏览742533

本站已经建立2382天!

热门文章
文章归档
回到顶部