一、模式示例
1.1、原理
1、定义
- 在模板模式(Template Pattern)中,一个抽象类公开定义了执行它的方法的方式/模板。它的子类可以按需要重写方法实现,但调用将以抽象类中定义的方式进行。这种类型的设计模式属于行为型模式。
2、介绍
-
意图:定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
-
主要解决:一些方法通用,却在每一个子类都重新写了这一方法。
-
何时使用:有一些通用的方法。
-
如何解决:将这些通用算法抽象出来。
-
关键代码:在抽象类实现,其他步骤在子类实现。
-
应用实例:
1、在造房子的时候,地基、走线、水管都一样,只有在建筑的后期才有加壁橱加栅栏等差异。
2、西游记里面菩萨定好的 81 难,这就是一个顶层的逻辑骨架。
3、spring 中对 Hibernate 的支持,将一些已经定好的方法封装起来,比如开启事务、获取 Session、关闭 Session 等,程序员不重复写那些已经规范好的代码,直接丢一个实体就可以保存。 -
优点:
1、封装不变部分,扩展可变部分。
2、提取公共代码,便于维护。
3、行为由父类控制,子类实现。 -
缺点:每一个不同的实现都需要一个子类来实现,导致类的个数增加,使得系统更加庞大。
-
使用场景:
1、有多个子类共有的方法,且逻辑相同。
2、重要的、复杂的方法,可以考虑作为模板方法。 -
注意事项:为防止恶意操作,一般模板方法都加上 final 关键词。
3、UML图
4、需求
- 造车:模板方法中包含组装车头、组装车身、组装车尾的业务处理逻辑,子类实现造车的抽象类;子类包括公交和吉普
5、角色
- 抽象角色:由抽象方法和模板方法组成
- 具体角色:实现抽象方法,包含具体的处理逻辑
- 模板方法:设置抽象方法的执行顺序或者逻辑
- 抽象方法:由具体角色继承实现,每一个具体角色的抽象方法内容都不一样
1.2、代码
1、抽象角色:造车类
public abstract class Car {
//模板类
public void make(){
makeHead();
makeBody();
makeTail();
}
public abstract void makeHead();
public abstract void makeBody();
public abstract void makeTail();
}
2、具体角色:公交
public class BusCar extends Car{
@Override
public void makeHead() {
System.out.println("公交:安装车头");
}
@Override
public void makeBody() {
System.out.println("公交:安装车身");
}
@Override
public void makeTail() {
System.out.println("公交:安装车尾");
}
}
3、具体角色:吉普
public class JeepCar extends Car {
@Override
public void makeHead() {
System.out.println("吉普:安装车头");
}
@Override
public void makeBody() {
System.out.println("吉普:安装车身");
}
@Override
public void makeTail() {
System.out.println("吉普:安装车尾");
}
}
4、启动类
public class TemplateApplication {
public static void main(String[] args) {
Car bus = new BusCar();
Car jeep = new JeepCar();
bus.make();
jeep.make();
}
}