Python设计模式详解之13 —— 模板方法模式

Template Method 设计模式 是一种行为型设计模式,用于定义一个操作的骨架,将某些步骤延迟到子类中实现,从而允许子类在不改变整体算法结构的情况下重新定义某些步骤。

在 Python 中,Template Method 模式通常使用基类的方法来定义通用算法框架,并通过子类覆盖特定步骤实现具体逻辑。


结构

  1. 抽象类: 提供算法的骨架,包含模板方法(定义算法步骤的顺序)和一些需要子类实现的抽象方法。
  2. 具体类: 实现抽象方法,定义算法的具体步骤。

代码示例

python 复制代码
from abc import ABC, abstractmethod

class AbstractWorkflow(ABC):
    """抽象类,定义算法的骨架"""

    def template_method(self):
        """模板方法,定义算法的框架"""
        self.step_one()
        self.step_two()
        self.hook()  # 可选步骤
        self.step_three()

    def step_one(self):
        """通用步骤"""
        print("Step 1: Common implementation.")

    @abstractmethod
    def step_two(self):
        """需要子类实现的抽象方法"""
        pass

    @abstractmethod
    def step_three(self):
        """需要子类实现的抽象方法"""
        pass

    def hook(self):
        """钩子方法,子类可选择性覆盖"""
        print("Default hook: Optional step.")

class ConcreteWorkflowA(AbstractWorkflow):
    """具体实现 A"""

    def step_two(self):
        print("Step 2 (A): Specific implementation for A.")

    def step_three(self):
        print("Step 3 (A): Specific implementation for A.")

class ConcreteWorkflowB(AbstractWorkflow):
    """具体实现 B"""

    def step_two(self):
        print("Step 2 (B): Specific implementation for B.")

    def step_three(self):
        print("Step 3 (B): Specific implementation for B.")

    def hook(self):
        print("Custom hook: Overridden by B.")

# 客户端代码
def client_code(workflow: AbstractWorkflow):
    workflow.template_method()

if __name__ == "__main__":
    print("Running ConcreteWorkflowA:")
    client_code(ConcreteWorkflowA())

    print("\nRunning ConcreteWorkflowB:")
    client_code(ConcreteWorkflowB())

运行结果

plaintext 复制代码
Running ConcreteWorkflowA:
Step 1: Common implementation.
Step 2 (A): Specific implementation for A.
Default hook: Optional step.
Step 3 (A): Specific implementation for A.

Running ConcreteWorkflowB:
Step 1: Common implementation.
Step 2 (B): Specific implementation for B.
Custom hook: Overridden by B.
Step 3 (B): Specific implementation for B.

模式要点

  1. 模板方法: 定义算法骨架,控制步骤的调用顺序。
  2. 抽象方法: 强制子类实现特定步骤。
  3. 钩子方法: 提供可选的扩展点,允许子类覆盖。
  4. 封装不变部分: 将通用逻辑放在基类中,确保不被子类破坏。
  5. 开放/封闭原则: 算法结构对扩展开放,对修改封闭。

优点

  • 避免重复代码,将通用逻辑提取到基类。
  • 子类只需关注特定步骤的实现,简化开发。
  • 灵活扩展特定步骤,而无需修改算法框架。

缺点

  • 如果算法步骤较多,可能导致类数量增加。
  • 继承限制了灵活性,无法动态改变算法步骤。

适用场景

  • 多个子类需要共享算法的通用部分。
  • 需要通过子类定制算法的某些步骤。
相关推荐
一晌小贪欢11 分钟前
Python 爬虫进阶:如何利用反射机制破解常见反爬策略
开发语言·爬虫·python·python爬虫·数据爬虫·爬虫python
躺平大鹅20 分钟前
5个实用Python小脚本,新手也能轻松实现(附完整代码)
python
yukai0800826 分钟前
【最后203篇系列】039 JWT使用
python
独好紫罗兰1 小时前
对python的再认识-基于数据结构进行-a006-元组-拓展
开发语言·数据结构·python
Dfreedom.1 小时前
图像直方图完全解析:从原理到实战应用
图像处理·python·opencv·直方图·直方图均衡化
铉铉这波能秀1 小时前
LeetCode Hot100数据结构背景知识之集合(Set)Python2026新版
数据结构·python·算法·leetcode·哈希算法
怒放吧德德2 小时前
Python3基础:基础实战巩固,从“会用”到“活用”
后端·python
aiguangyuan2 小时前
基于BERT的中文命名实体识别实战解析
人工智能·python·nlp
喵手2 小时前
Python爬虫实战:知识挖掘机 - 知乎问答与专栏文章的深度分页采集系统(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集知乎问答与专栏文章·采集知乎数据·采集知乎数据存储sqlite
铉铉这波能秀2 小时前
LeetCode Hot100数据结构背景知识之元组(Tuple)Python2026新版
数据结构·python·算法·leetcode·元组·tuple