1、定义前端
定义了一个算法的骨架,并容许子类为一个或多个步骤提供实现java
模板方法使子类能够在不改变算法结构的状况下,从新定义算法的某些步骤算法
类型:行为型后端
2、适用场景设计模式
一次性实现一个算法的不变部分,并将可变的行为留给子类来实现ide
各子类中公共的行为被提取出来并集中到一个公共父类中,从而避免代码重复测试
3、优势this
一、提升复用性设计
二、提升扩展性视频
三、符合开闭原则
4、缺点
一、类数目增长
二、增长了系统实现的复杂度
三、继承关系自身缺点,若是父类添加新的抽象方法,全部子类都要改一遍
5、模板方法-扩展
一、钩子方法
6、模板方法-相关设计模式
一、模板方法模式和工厂方法模式
工厂方法是模板方法的一种特殊实现。
二、模板方法模式和策略模式
策略模式:使不一样的算法能够相互替换,并不影响客户处应用端的使用。能够改变算法的流程。若是代码中有大量的If-Else,能够考虑策略模式。
模板方法:针对定义一个算法的流程,将一些不太同样具体实现步骤交给子类实现。模板方法不改变算法的流程。
7、Coding
一、ACourse抽象类
public abstract class ACourse { protected final void makeCourse(){ this.makePPT(); this.makeVideo(); if(needWrite()){ 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 needWrite(){ return false; } abstract void packageCourse(); }
二、 DesignPatternCourse类
public class DesignPatternCourse extends ACourse { @Override void packageCourse() { System.out.println("提供课程Java源代码"); } @Override protected boolean needWrite() { return true; } }
三、FECourse类
/** * 前端课程 */ public class FECourse extends ACourse { @Override void packageCourse() { System.out.println("提供课程前端源代码"); System.out.println("提供课程图片等多媒体素材"); } }
四、测试
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(); feCourse.makeCourse(); System.out.println("前端设计模式课程end---"); } }
五、输出结果
后端设计模式课程start--- 制做PPT 制做视频 编写手记 提供课程Java源代码 后端设计模式课程end--- 前端设计模式课程start--- 制做PPT 制做视频 提供课程前端源代码 提供课程图片等多媒体素材 前端设计模式课程end---
六、UML图
四、前端课程 控制needWrite
/** * 前端课程 */ public class FECourse extends ACourse { private boolean needWriteArticleFlag = false; @Override void packageCourse() { System.out.println("提供课程前端源代码"); System.out.println("提供课程图片等多媒体素材"); } public void setNeedWriteArticleFlag(boolean needWriteArticleFlag) { this.needWriteArticleFlag = needWriteArticleFlag; } @Override protected boolean needWrite() { return needWriteArticleFlag; } }