模板方法定义了一个算法的步骤,并允许子类为一个或者多个步骤提供实现。
说起模板方法模式,笔者就想起刚开始编写数据库操作代码的场景,在无框架支持的前提下,每次跟数据库的交互都要加载驱动、创建连接、准备语句、执行语句、结果处理、关闭连接、异常处理等步骤。但是仔细观察,很多操作其实都是一样的,因此在Spring中,引入了JDBCTemplate概念,为数据库操作指定了模板、不同厂商的数据库只要实现相应的模板中的接口便可实现数据库操作。
模板方法模式的类图如下:
我们定义一个模板方法:
public abstract class AbstractMethod {
//模板方法
final void templateMethod(){
System.out.println("调用模板方法开始");
subMethod();
System.out.println("调用模板方法结束");
}
//抽象方法,等待子类实现
public abstract void subMethod();
}
我们再定义两个子类:
public class ConcreteMethod01 extends AbstractMethod {
public void subMethod() {
System.out.println("这是ConcreteMethod01类的具体实现");
}
}
public class ConcreteMethod02 extends AbstractMethod {
public void subMethod() {
System.out.println("这是ConcreteMethod02类的具体实现");
}
}
最后我们来编写测试类:
public class TemplateMethodTest {
public static void main(String[] args) {
ConcreteMethod01 c1 = new ConcreteMethod01();
ConcreteMethod02 c2 = new ConcreteMethod02();
c1.templateMethod();
System.out.println("\n====================\n");
c2.templateMethod();
}
}
我们看一下运行结果:
模板方法将相同部分的代码放在抽象的父类中,提高了代码的复用性,同时通过一个父类调用其子类的操作,通过对子类的扩展增加新的行为,实现了反向控制,符合“开闭原则”,但是这也会导致类的个数增加,从而增加了系统实现的复杂度。