一、简介
1.1 模式定义
一个操作中算法的骨架,而将一些步骤延迟到子类中,模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。模板方法是一种类行为模式。
1.2 适用场景
1)模板方法模式广泛应用于架构设计中,一确保父类控制处理流程的逻辑顺序(如框架的初始化)。
2)各子类中公共的行为应被提取出来并集中到一个公共父类中以避免代码重复。首先需要识别现有代码中的不同之处,并且将不同之处分离为新的操作;然后,用一个调用这些新的操作的模板方法来替换这些不同的代码。
3)对一些复杂的算法进行分割,将其算法中固定不变的部分设计为模板方法和父类具体方法,而一些可以改变的细节由其子类来实现。
4)控制子类的扩展。模板方法只在特定点调用钩子方法,这样就只允许在这些点进行扩展,也就是说对于某些方法,可以通过钩子方法进行扩展,而对于不能进行扩展的方法可以将其定义为final方法,对算法的扩展进行有效的控制和约束。
1.3 优点
1)模板方法模式在一个类中形式化地定义算法,而由它的子类实现细节的处理。模板方法模式的优势是在子类定义详细的处理算法时不会改变算法的结构。
2)模板方法模式是一种代码复用的基本技术,它在类库设计中尤为重要,它提取了类库中的公共行为,将公共行为放在父类中,而通过其子类来实现不同的行为。
3)模板方法模式导致一种反向的控制结构,通过一个父类调用其子类的操作,通过对子类的扩展增加新的行为,符合“开闭原则”。
1.4 缺点
每个不同的实现都需要定义一个子类,这会导致类的个数增加,系统更加庞大,设计更加抽象,但是更加符合“单一职责原则”,使得类的内举行得以提高。
二、示例:模板方法模式
2.1 结构图
2.2 抽象类BankTemplateMethod (银行业务办理流程类)
public abstract class BankTemplateMethod {
public void takeNumber() {
System.out.println("取号排队...");
}
public abstract void transact();
public void evaluate() {
System.out.println("反馈评分.");
}
public void process() {
this.takeNumber();
this.transact();
this.evaluate();
}
}
2.3 具体子类Deposit(存款类)
public class Deposit extends BankTemplateMethod{
@Override
public void transact() {
System.out.println("存款");
}
}
2.4 具体子类Withdraw(取款类)
public class Withdraw extends BankTemplateMethod{
@Override
public void transact() {
System.out.println("取款");
}
}
2.5 其他子类Transfer(转账类)
public class Transfer extends BankTemplateMethod{
@Override
public void transact() {
System.out.println("转账");
}
}