一、原理与实现
模板方法模式在一个方法中定义一个算法骨架,并将某些步骤推迟到子类中实现。模板方法模式可以让子类在不改变算法整体结构的情况下,重新定义算法中的某些步骤。
这里的“算法”,我们可以理解为广义上的“业务逻辑”,并不特指数据结构和算法中的“算法”。这里的算法骨架就是“模板”,包含算法骨架的方法就是“模板方法”,这也是模板方法模式名字的由来。
下面是一个简单的Java示例,展示了如何使用模板方法设计模式:
1、首先,创建一个抽象类,定义算法的骨架:
public abstract class AbstractTemplate {
//定义算法骨架,用final修饰为了不让其子类重写
public final void template(){
step1();
step2();
step3();
}
// 基本方法,定义算法中不会变化的步骤
private void step1() {
System.out.println("步骤1");
}
// 抽象方法,定义算法中需要子类实现的步骤
public abstract void step2();
// 基本方法,定义算法中不会变化的步骤
private void step3() {
System.out.println("步骤3");
}
}
2、然后,创建具体的子类,实现抽象类中定义的抽象方法:
public class ConcreteTemplateA extends AbstractTemplate{
@Override
public void step2() {
System.out.println("步骤2A");
}
}
3、最后,在客户端代码中使用模板方法:
public class Test {
public static void main(String[] args) {
AbstractTemplate template = new ConcreteTemplateA();
template.template();
}
}
二、应用场景
将通用逻辑和特定逻辑分离,提高代码复用性和可维护性。以下是一些典型的应用场景:
- 支付流程:电商系统通常需要支持多种支付方式(如信用卡支付、支付宝支付、微信支付等)。虽然不同的支付方式在实现细节上有所不同,但它们的整体流程是相似的。可以使用模板方法设计模式创建一个支付流程抽象类,定义通用的支付流程骨架,然后通过子类实现各种具体支付方式的逻辑。
- 订单处理:电商系统的订单处理流程通常包括一系列步骤,如验证库存、计算价格、生成运单等。这些步骤中,有些是通用的,而有些可能因订单类型、商品类型等因素而异。可以使用模板方法设计模式创建一个订单处理抽象类,定义通用的订单处理流程骨架,然后通过子类实现特定订单类型或商品类型的逻辑。
- 促销策略:电商系统中的促销活动通常具有多种策略(如满减、打折、赠品等)。尽管不同策略的具体实现不同,但它们都需要进行一些通用操作(如获取用户信息、验证促销条件等)。可以使用模板方法设计模式创建一个促销策略抽象类,定义通用的促销操作骨架,然后通过子类实现各种具体促销策略的逻辑。
- 报表生成:电商系统需要生成各种报表(如销售报表、库存报表、财务报表等)。这些报表在数据查询和报表样式上可能有所不同,但它们的生成流程是类似的(如查询数据、生成报表、导出文件等)。可以使用模板方法设计模式创建一个报表生成抽象类,定义通用的报表生成流程骨架,然后通过子类实现具体报表类型的逻辑。