C# 设计模式(行为型模式):模板方法模式

C# 设计模式(行为型模式):模板方法模式

在开发过程中,我们经常会遇到一类问题:一些操作的整体步骤是固定的,但某些具体步骤的实现会因为场景不同而有所变化。模板方法模式(Template Method Pattern)是一种行为型设计模式,能够很好地解决这类问题。

模板方法模式的定义

模板方法模式定义了一个算法的框架,并允许子类在不改变算法结构的情况下重新定义某些步骤的实现。它通过将算法的可变部分延迟到子类中,使代码的复用性更高,扩展性更好。

模板方法模式的结构

模板方法模式包括以下角色:

  1. AbstractClass(抽象类): 定义算法的骨架,包括模板方法和抽象方法。
  2. ConcreteClass(具体子类): 实现抽象方法,提供特定的逻辑。

示例:咖啡和茶的制作流程

我们以制作咖啡和茶为例,两者的制作步骤相似,但某些具体操作不同:

  1. 烧水。
  2. 冲泡饮品(咖啡或茶)。
  3. 倒入杯中。
  4. 添加配料(糖、牛奶或柠檬)。

代码实现

csharp 复制代码
using System;

// 抽象类:饮品制作模板
public abstract class BeverageTemplate
{
    // 模板方法:定义制作流程
    public void PrepareBeverage()
    {
        BoilWater();
        Brew();
        PourInCup();
        AddCondiments();
    }

    // 通用步骤:烧水
    private void BoilWater()
    {
        Console.WriteLine("烧水中...");
    }

    // 通用步骤:倒入杯中
    private void PourInCup()
    {
        Console.WriteLine("将饮品倒入杯中。");
    }

    // 抽象方法:冲泡饮品
    protected abstract void Brew();

    // 抽象方法:添加配料
    protected abstract void AddCondiments();
}

// 具体类:咖啡
public class Coffee : BeverageTemplate
{
    protected override void Brew()
    {
        Console.WriteLine("用热水冲泡咖啡。");
    }

    protected override void AddCondiments()
    {
        Console.WriteLine("添加糖和牛奶。");
    }
}

// 具体类:茶
public class Tea : BeverageTemplate
{
    protected override void Brew()
    {
        Console.WriteLine("用热水浸泡茶叶。");
    }

    protected override void AddCondiments()
    {
        Console.WriteLine("添加柠檬。");
    }
}

// 测试代码
class Program
{
    static void Main(string[] args)
    {
        Console.WriteLine("制作咖啡:");
        BeverageTemplate coffee = new Coffee();
        coffee.PrepareBeverage();

        Console.WriteLine();

        Console.WriteLine("制作茶:");
        BeverageTemplate tea = new Tea();
        tea.PrepareBeverage();
    }
}

输出结果

复制代码
制作咖啡:
烧水中...
用热水冲泡咖啡。
将饮品倒入杯中。
添加糖和牛奶。

制作茶:
烧水中...
用热水浸泡茶叶。
将饮品倒入杯中。
添加柠檬。

模板方法模式的优缺点

优点

  1. 代码复用性高: 提取通用代码到抽象类中,避免重复代码。
  2. 灵活性强: 子类可以灵活实现具体步骤,而无需改变算法结构。
  3. 遵循开闭原则: 新增具体实现时,只需添加新子类,无需修改抽象类。

缺点

  1. 继承关系局限: 如果抽象类发生变化,所有子类都需要修改。
  2. 子类数量增加: 每个具体实现都需要一个子类。

适用场景

  1. 一个操作有固定的步骤,但某些步骤需要子类定制化实现。
  2. 有多个类的行为逻辑相似,但在细节实现上有所不同。

总结

模板方法模式是将不变的行为放在父类中,具体的实现延迟到子类中,从而实现了代码复用和灵活扩展。在实际开发中,例如工作流引擎、报表生成等场景,都可以看到模板方法模式的身影。

相关推荐
用户298698530146 小时前
.NET 文档自动化:Spire.Doc 设置奇偶页页眉/页脚的最佳实践
后端·c#·.net
用户3667462526747 小时前
接口文档汇总 - 2.设备状态管理
c#
用户3667462526747 小时前
接口文档汇总 - 3.PLC通信管理
c#
Ray Liang1 天前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
七月丶1 天前
别再手动凑 PR 了:这个 AI Skill 会按仓库习惯自动建分支、拆提交、提 PR
人工智能·设计模式·程序员
刀法如飞1 天前
从程序员到架构师:6大编程范式全解析与实践对比
设计模式·系统架构·编程范式
九狼1 天前
Flutter + Riverpod +MVI 架构下的现代状态管理
设计模式
静水流深_沧海一粟2 天前
04 | 别再写几十个参数的构造函数了——建造者模式
设计模式
StarkCoder2 天前
从UIKit到SwiftUI的迁移感悟:数据驱动的革命
设计模式
阿星AI工作室2 天前
给openclaw龙虾造了间像素办公室!实时看它写代码、摸鱼、修bug、写日报,太可爱了吧!
前端·人工智能·设计模式