设计模式
本系列文章均是博主原创,意在记录学习上的知识,同时一起分享学习心得。前言
本章节介绍模板模式,包括模板模式的原理与实现,以及应用场景。
一、原理和实现
模板模式,全称是模板方法设计模式。模板方法模式在一个方法中定义一个算法骨架,并将某些步骤推迟到子类中实现。模板方法模式可以让子类在不改变算法整体结构的情况下,重新定义算法中的某些步骤。
模板模式的常用实现思路如下:
- 定义一个抽象类,类中实现了一个final类型的模板方法,该方法可能会调用抽象类中的其他抽象方法。
- 定义实现类,并继承第一步的抽象类,实现对应的抽象方法。
- 使用时,用实现类构造对象,执行其父类的模板方法。
代码如下(示例):
public abstract class AbstParser {
public final void parse() {
// doSomeThing...
System.out.println("模板方法实现");
handelLine();
handelRow();
}
abstract public void handelLine();
abstract public void handelRow();
}
public class TxtParser extends AbstParser {
@Override
public void handelLine() {
System.out.println("处理txt一行");
}
@Override
public void handelRow() {
System.out.println("处理txt整行");
}
}
public class XmlParser extends AbstParser {
@Override
public void handelLine() {
System.out.println("处理xml一行");
}
@Override
public void handelRow() {
System.out.println("处理xml整行");
}
}
二、应用场景
在了解模板模式应用场景前,首先需要知道模板模式的两大作用:复用和扩展。
- 复用
模板模式把一个算法中不变的流程抽象到父类的模板方法中,将可变的部分留给子类实现。所有的子类都可以复用父类中的模板方法定义的流程代码。 - 扩展
这里的扩展并不是代码的扩展性,而是指框架的扩展性,有点类似控制反转。基于这个作用,模板模式常用在框架的开发中,让框架用户可以在不修改框架源码的情况下,定制化框架的功能。
在JDK源码中模板模式应用场景有很多,比如InputStream、AbstractList、Servlet、JUnit TestCase等都用到了模板模式。
当我们的业务系统中,如果对某类算法,其流程是固定的,只是在某一个步骤的实现逻辑各有不同,为了复用和更好的扩展,可以使用模板模式,将不变的流程写在模板方法中,把步骤的实现逻辑交给子类。
总结
在模板模式经典实现中,模板方法定义为final,可以避免被子类重写。需要子类重写的方法定义为abstract,可以强迫子类去实现。不过,在实际开发中,这两项都不是必须的。模板模式有两大作用:复用和扩展。其中,复用指的是,所有子类可以复用父类中提供的模板方法的代码。扩展指的是,框架通过模板模式提供功能扩展点,让框架用户可以在不修改源码的情况下,基于扩展点定制化框架的功能。