当前位置: 首页 > article >正文

行为型设计模式-模板方法(template method)模式

设计模式汇总:查看

通俗示例

想象一下你正在制作一杯咖啡,制作咖啡的步骤大致相同,但有些步骤可以根据个人口味进行调整,比如选择咖啡豆、添加糖和奶等。在这种情况下,可以定义一个“制作咖啡”的模板,它规定了制作咖啡的基本步骤,但将某些步骤的具体实现留给子类完成。这就是模板方法模式的一个例子,其中模板定义了算法的骨架,而将一些步骤的实现延迟到子类中。

通俗解释

模板方法模式是一种行为型设计模式,它在一个方法中定义一个算法的骨架,将算法的某些步骤延迟到子类中实现。模板方法模式允许子类在不改变算法结构的情况下,重新定义算法中的某些步骤。

模板方法模式的组成通常包括以下几部分:

  • 抽象类(Abstract Class):定义了一个或多个抽象操作,以及一个模板方法。这个模板方法定义了算法的骨架,并调用在这些抽象操作。
  • 具体类(Concrete Class):实现抽象类中的抽象操作,也可以覆盖模板方法中的可钩子操作(hook)。

模板方法模式的优点

  • 复用性:模板方法定义了算法的骨架,提高了代码的复用性。
  • 扩展性:子类可以覆盖特定的步骤,从而实现特定的行为。
  • 维护性:模板方法模式有助于维护一个一致的方法接口。

Python代码示例

以下是一个模板方法模式的简单实现:

from abc import ABC, abstractmethod

# 抽象类
class CoffeeMaker(ABC):
    def make_coffee(self):
        self.boil_water()
        self.brew_coffee_beans()
        self.add_condiments()
        print("Coffee is ready!")
    
    def boil_water(self):
        print("Boiling water...")
    
    @abstractmethod
    def brew_coffee_beans(self):
        pass
    
    @abstractmethod
    def add_condiments(self):
        pass

# 具体类
class LatteMaker(CoffeeMaker):
    def brew_coffee_beans(self):
        print("Brewing coffee beans for latte...")
    
    def add_condiments(self):
        print("Adding milk and sugar for latte...")

class BlackCoffeeMaker(CoffeeMaker):
    def brew_coffee_beans(self):
        print("Brewing coffee beans for black coffee...")
    
    def add_condiments(self):
        print("No condiments for black coffee.")

# 客户端代码
if __name__ == "__main__":
    latte_maker = LatteMaker()
    latte_maker.make_coffee()
    
    print()
    
    black_coffee_maker = BlackCoffeeMaker()
    black_coffee_maker.make_coffee()

在这个例子中,CoffeeMaker是一个抽象类,它定义了make_coffee这个模板方法,该方法规定了制作咖啡的步骤。同时,它还定义了两个抽象方法brew_coffee_beansadd_condiments,这两个方法需要在子类中实现。LatteMakerBlackCoffeeMaker是具体类,它们实现了抽象方法,从而定义了制作拿铁和黑咖啡的具体步骤。

总结

模板方法模式通过在一个方法中定义算法的骨架,将算法的某些步骤的实现推迟到子类中,从而允许子类在不改变算法结构的情况下,重新定义算法中的某些步骤。这种模式特别适用于那些具有多个步骤,其中一些步骤经常变化而另一些保持不变的情况。


http://www.kler.cn/a/282421.html

相关文章:

  • 环境贴图选用方式
  • xcode-select: error: tool ‘xcodebuild‘ requires Xcode, but active developer
  • Vulhub漏洞复现---solr---CVE-2019-17558
  • YOLOv5、YOLOv6、YOLOv7、YOLOv8、YOLOv9、YOLOv10、YOLOv11 推理的 C++ 和 Python 实现
  • 基于Matlab的碎纸片的自动拼接复原技术
  • 数据分析-48-时间序列变点检测之在线实时数据的CPD
  • 数据结构(邓俊辉)学习笔记】串 17——Karp-Rabin算法:散列
  • 数据结构:栈、队列详解篇
  • Java 集合之List
  • C++ STL adjacent_find 用法与实现
  • VMware16安装包+详细安装教程
  • 虚拟机Ubuntu误操作导致无法自动联网的解决办法
  • (第三十七天)
  • Unity(2022.3.41LTS) - 着色器
  • 【自由能系列(初级)】大脑功能与贝叶斯计算——深层生成模型的自由能原理
  • junit格式报告解析工具
  • shell脚本-采集容器内自定义端口tcp连接数并通过http接口推送到Prometheus
  • Ruby 多线程
  • UTONMOS:探索未来游戏的元宇宙纪元新篇章
  • 微知-nandflash和norflash名字为什么叫nand和nor?主要区别是什么?
  • js | XMLHttpRequest
  • 【QT | 开发环境搭建】Linux系统(Ubuntu 18.04) 安装 QT 5.12.12 开发环境
  • MyBatis 源码解析:Environment 与 DataSource 配置实现
  • 【网络安全】服务基础第一阶段——第五节:Windows系统管理基础---- DHCP部署与安全
  • 您应该让 ChatGPT 控制您的浏览器吗?
  • VTK+Qt+Cmake+VS的环境搭建