软件设计模式白话文系列(十三)模版方法模式

1、模式描述

模版方法模式属于行为型模式,在父类中定义业务框架,并将某些步骤的实现延迟到子类实现,允许子类在不影响框架接口的的情况下,重写某些步骤。

2、模式结构

  • 模版类:定义出业务执行步骤和骨架(模版方法),定义每个步骤的抽象规范,部分步骤可以默认实现。
  • 具体业务实现类:继承或实现模版类,实现所有步骤的规范。

3、 实现逻辑

模版方法模式本质是将一个业务分解为一系列步骤(分解封装为多个方法),然后将在模版方法中依次调用。分解出来的方法可以是抽象的,但客户端调用时必须实现这些步骤,必要时可以重写默认方法。

4、实战代码

这里模拟银行业务来举例说明,一般银行办理业务存在4个步骤:取号、排队、业务办理、业务评价。

/**
 * 模版类
 *
 * @author Eajur.Wen
 * @version 1.0
 * @date 2022-11-16 15:49:18
 */
public abstract class BlankService {
    protected String clientName;

    public BlankService(String clientName) {
        this.clientName = clientName;
    }

    public void service() {
        takeNumber();
        queueUp();
        handleBusiness();
        evaluate();
    }

    public void takeNumber() {
        System.out.println(clientName + " 客户取号");
    }

    public void queueUp() {
        System.out.println(clientName + " 客户排队等候中");
    }

    public abstract void handleBusiness();

    public void evaluate() {
        System.out.println(clientName + " 客户评分");
    }

}

/**
 * 具体业务实现类
 *
 * @author Eajur.Wen
 * @version 1.0
 * @date 2022-11-16 16:53:53
 */
public class DrawMoneyService extends BlankService {
    public DrawMoneyService(String clientName) {
        super(clientName);
    }

    @Override
    public void handleBusiness() {
        System.out.println(clientName + " 办理取款业务");
    }
}

/**
 * 具体业务实现类
 *
 * @author Eajur.Wen
 * @version 1.0
 * @date 2022-11-16 16:53:53
 */
public class SaveMoneyService extends BlankService {
    public SaveMoneyService(String clientName) {
        super(clientName);
    }
    @Override
    public void handleBusiness() {
        System.out.println(clientName + " 办理存款业务");
    }
}

/**
 * 测试类
 *
 * @author Eajur.Wen
 * @version 1.0
 * @date 2022-11-16 16:55:46
 */
public class Client {
    public static void main(String[] args) {
        new DrawMoneyService("Eajur Wen1").service();
        System.out.println("---------");
        new SaveMoneyService("Eajur Wen2").service();
    }
}

执行结果:

其中取号、排队、业务评价流程是固定的,我们可以在模版类默认实现;业务办理则是动态的,就交由具体业务实现类去实现。

5、适用场景

  • 存在固定业务逻辑,但存在少量差异的情况。
  • 存在多个相似业务,可以根据模版方法提取模版类,通过实现具体业务类来减少冗余的重复代码。