简介
模板方法模式(Template Method Pattern),又叫模板模式(Template Pattern),是一种行为设计模式,它定义了一个操作中的算法框架,将某些步骤的具体实现留给子类。通过模板方法模式,我们可以在不改变算法结构的情况下,允许子类重新定义某些步骤,从而实现代码复用和扩展。
在软件开发中,我们经常会遇到需要定义一组相似操作的场景。这些操作可能在整体上有着相同的结构,但在细节上有所差异。如果每次都重复编写这些操作的通用结构,会导致代码的冗余性,同时也增加了后期维护的难度。为了解决这个问题,模板方法模式应运而生。
角色
- 抽象类(Abstract Class):抽象类定义了算法的框架,包括一个或多个抽象方法和具体方法。其中的抽象方法由子类实现,具体方法可以被子类直接继承或重写。
- 具体子类(Concrete Subclass):具体子类继承抽象类,并根据需要实现其中的抽象方法。具体子类提供了算法的具体实现细节。
优点
- 代码复用:模板方法模式通过将算法的通用结构定义在抽象类中,可以使子类直接继承这些通用部分,从而达到代码复用的目的。
- 扩展性:模板方法模式允许子类根据需要重写父类的某些步骤,从而实现对算法的自由扩展和修改,同时保持整体结构的稳定性。
- 封装性:模板方法模式将算法的实现细节封装在抽象类中,对调用者屏蔽了具体的实现细节,只暴露出高层接口。
缺点
- 模板方法模式将算法的执行流程固定在抽象类中,可能会导致代码的可读性降低,增加理解和维护的难度。
- 模板方法中的步骤越多, 其维护工作就可能会越困难。
- 通过子类抑制默认步骤实现可能会导致违反里氏替换原则。
应用场景
- 当存在一组相似的操作,它们具有相同的算法结构,但实现细节各不相同时。
- 当希望在不改变算法的整体结构的情况下,允许子类自由扩展或修改某些步骤时。
- 当希望将算法的实现细节封装起来,只暴露出高层接口供调用者使用时。
实现
- 定义一个抽象类或接口作为基类,其中包含模板方法以及一些抽象方法或虚方法
public abstract class TemplateMethodPattern
{
// 模板方法
public final void TemplateMethod()
{
Console.WriteLine("执行固定步骤1...");
ConcreteMethod(); // 调用抽象方法或虚方法
Console.WriteLine("执行固定步骤2...");
}
// 抽象方法或虚方法,子类需要实现这些方法以提供具体逻辑
protected abstract void ConcreteMethod();
}
- 创建具体的子类并实现抽象方法或虚方法
public class ConcreteClassA : TemplateMethodPattern
{
// 实现抽象方法或虚方法
protected override void ConcreteMethod()
{
Console.WriteLine("子类A的具体实现步骤...");
}
}
public class ConcreteClassB : TemplateMethodPattern
{
protected override void ConcreteMethod()
{
Console.WriteLine("子类B的具体实现步骤...");
}
}
- 上层应用调用
class Program
{
static void Main(string[] args)
{
ConcreteClassA concreteClassA = new ConcreteClassA();
concreteClassA.TemplateMethod(); // 输出固定步骤和子类A的具体实现步骤
ConcreteClassB concreteClassB = new ConcreteClassB();
concreteClassB.TemplateMethod(); // 输出固定步骤和子类B的具体实现步骤
}
}
在这个案例中,TemplateMethodPattern
类定义了一个模板方法 TemplateMethod
,它包含了一些固定的步骤以及一个抽象方法 ConcreteMethod
。子类 ConcreteClassA
和 ConcreteClassB
分别实现了 ConcreteMethod
方法以提供它们自己的具体逻辑。当调用 TemplateMethod
时,固定的步骤会执行,然后调用子类提供的具体实现。这样,你就可以确保算法的某些步骤始终被执行,同时允许子类根据需要提供额外的实现。