定义:定义了一个算法的骨架,并容许子类为一个或多个步骤提供实现
模板方法使得子类能够在不改变算法结构的状况下,从新定义算法的某些步骤
类型:行为型前端
一次性实现一个算法的不变的部分,并将可变的行为留给子类来实现
各子类中公共的行为被提取出来并集中到一个公共父类中,从而避免代码重复算法
提升复用性
提升扩展性
符合开闭原则后端
类数目增长
增长了系统实现的复杂度
继承关系自身缺点,若是父类添加新的抽象方法,全部子类都要改一遍设计模式
钩子方法tomcat
模板方法模式和工厂方法模式ide
模板方法模式和策略模式
策略模式是使不一样的算法能够相互替换,而且不影响应用层客户端的使用,能够改变算法的流程;而模板方法模式是针对顶一个算法的流程,将一些不太同样的步骤交给子类去实现,不改变算法的流程测试
模拟场景:制做课程,有些步骤和操做是固定的,但打包的时候每一个课程都有本身的打包方式,而且课程不必定有手记this
课程抽象类:设计
public abstract class ACourse { protected final void makeCourse(){ // 固定好步骤 this.makePPT(); this.makeVideo(); if(needWriteArticle()){ this.writeArticle(); } this.packageCourse(); } final void makePPT(){ System.out.println("制做PPT"); } final void makeVideo(){ System.out.println("制做视频"); } final void writeArticle(){ System.out.println("编写手记"); } //钩子方法 protected boolean needWriteArticle(){ return false; } // 交给子类实现 abstract void packageCourse(); }
课程实现类1:code
public class DesignPatternCourse extends ACourse { @Override void packageCourse() { System.out.println("提供课程Java源代码"); } @Override protected boolean needWriteArticle() { return true; } }
课程实现类2:
public class FECourse extends ACourse { private boolean needWriteArticleFlag = false; @Override void packageCourse() { System.out.println("提供课程的前端代码"); System.out.println("提供课程的图片等多媒体素材"); } public FECourse(boolean needWriteArticleFlag) { this.needWriteArticleFlag = needWriteArticleFlag; } @Override protected boolean needWriteArticle() { return this.needWriteArticleFlag; } }
测试类:
public class Test { public static void main(String[] args) { System.out.println("后端设计模式课程start---"); ACourse designPatternCourse = new DesignPatternCourse(); designPatternCourse.makeCourse(); System.out.println("后端设计模式课程end---"); System.out.println("前端课程start---"); ACourse feCourse = new FECourse(false); feCourse.makeCourse(); System.out.println("前端课程end---"); } }
AbstractSet、AbstractMap同理