定义
模板方法模式(Template Method Pattern):定义一个操作中的算法的框架,而将一些步骤延迟到子类中;使得子类可以不改变一个算法的结构即可重新定义该算法的某些特殊步骤
模板方法模式比较简单,主要就是使用了java的继承机制,其中的AbstractClass就是抽象模板类
在抽象模板类中,方法分为两类:
- 基本方法:也称之为基本操作,是要由子类实现的方法,并且在模板方法中被调用
- 模板方法:可以有一个或是多个,一般是一个具体的方法,实现对基本方法的调用,完成所需要的逻辑
注意:一般为了防止恶意的操作,模板方法上都会加上final关键字,不允许被覆写
通用源码
//抽象模板类
public abstract class AbstractClass {
//基本方法
protected abstract void doSomething1();
//基本方法
protected abstract void doSomething2();
//模板方法
public void templateMethod() {
//调用基本方法,完成所需逻辑
this.doSomething1();
this.doSomething2();
}
}
//具体模板类
public class ConcreteClass1 extends AbstractClass {
//实现基本方法
protected void doSomething1(){
...//业务逻辑
}
protected void doSomething2(){
...//业务逻辑
}
}
public class ConcreteClass2 extends AbstractClass {
//实现基本方法
protected void doSomething1(){
...//业务逻辑
}
protected void doSomething2(){
...//业务逻辑
}
}
//场景类
public class Client {
public static void main(String[] args) {
AbstractClass class1 = new ConcreteClass1();
AbstractClass class2 = new ConcreteClass2();
//调用模板方法
class1.templateMethod();
class2.templateMethod();
}
}
注意:抽象模板类中的基本方法尽量用protected修饰,符合迪米特法则
应用
优点
- 封装不可变部分,扩展可变部分:把不可变得部分封装到父类中实现,可变的部分通过继承来继续扩展
- 提取公共部分代码,便于维护
- 行为由父类控制,由子类实现:基本方法由子类实现,所以子类可以通过扩展的方式增加相应的功能,符合开闭原则
缺点
按照我们正常的习惯时,都是抽象类声明抽象,实现类实现具体;但是模板方法模式却相反,抽象类定义类部分抽象,由子类实现,子类的执行结果又影响了父类的结果,也就是子类对父类产生了影响
使用场景
- 多个子类有公有的方法,并且逻辑基本相同
- 重要复杂的算法,可以把最核心的部分设计为模板方法