设计模式课程 设计模式精讲 17-2 模板方法模式coding
1 代码演练
1.1 代码演练1
1.2 代码演练2(后端课程子类运用钩子方法,加入写手记的方法)
1.3 代码演练3(前端有多个子类,有得需要写手记,有得不需要写,如何实现?)
1 代码演练
1.1 代码演练1
目的:
木木网制作课程视频父类,前端课程子类和设计模式子类。父类需要制作PPT,制作视频,制作手记,包装课程四个部分,且步骤基本一致,其中制作PPT和制作视频都一致,前端子类和后端子类包装课程方法不一样。
uml类图:
测试类:
package com.geely.design.pattern.behavioral.templatemethod; public class Test {
public static void main(String [] args){ System.out.println("=======================后端课程开始");
ACourse aCourse1 = new DesignPatternCourse();
aCourse1.makeCourse();
System.out.println("=======================后端课程结束"); System.out.println("=======================前端课程开始");
ACourse aCourse2 = new FECourse();
aCourse2.makeCourse();
System.out.println("=======================前端课程结束");
}
}
抽象课程父类:
package com.geely.design.pattern.behavioral.templatemethod; /**
* 制作抽象类 课程类,用于被其他类继承
*/
public abstract class ACourse { /**
* 整合课程 的方法,
* 该流程是固定的,子类不能重写
*/
protected final void makeCourse(){
makePPT();
makeVideo();
if(needMakeArticle()){
makeArticle();
}
packageCourse();
}
/**
* 制作PPT 方法
* 目的:如果想要每个子类都不能重写该方法,就用final修饰
* 原因:每个子类都必须有制作PPT的方法
*/
final void makePPT(){
System.out.println("开始制作PPT");
} /**
* 同上
*/
final void makeVideo(){
System.out.println("制作课程视频");
} /**
* 制作手记方法
* 该方法不可被重写
* 有的课程需要制作,有的课程不需要
*/
final void makeArticle(){
System.out.println("编写手记");
} /**
* 添加钩子方法
* 该方法可被子类重写,用于判断子类是否需要制作手记
* @return
*/
protected boolean needMakeArticle(){
return false;
} /**
* 包装课程方法,
* 目的:不同的课程,包装的素材也不一样,所以声明抽象的,子类可以重写
*/
abstract void packageCourse();
}
前端子类:
package com.geely.design.pattern.behavioral.templatemethod; public class FECourse extends ACourse{
/**
* 不同子类实现不同包装方法
*/
@Override
void packageCourse() {
System.out.println("提供课程前端代码");
System.out.println("提供课程图片素材");
}
}
后端子类:
package com.geely.design.pattern.behavioral.templatemethod; /**
* 设计模式课程,
* 业务场景:不用编写手记
*/
public class DesignPatternCourse extends ACourse{
/**
* 不同子类实现不同包装方法
*/
@Override
void packageCourse() {
System.out.println("后端包装方法实现");
}
}
打印结果:
=======================后端课程开始
开始制作PPT
制作课程视频
后端包装方法实现
=======================后端课程结束
=======================前端课程开始
开始制作PPT
制作课程视频
提供课程前端代码
提供课程图片素材
=======================前端课程结束 Process finished with exit code 0
1.2 代码演练2(后端课程子类运用钩子方法,加入写手记的方法)
重点:
后端课程子类
后端课程子类:
package com.geely.design.pattern.behavioral.templatemethod; /**
* 设计模式课程,
* 业务场景:不用编写手记
*/
public class DesignPatternCourse extends ACourse{
/**
* 钩子方法,后端课程加入编写手记方法
* @return
*/
@Override
protected boolean needMakeArticle() {
return true;
} /**
* 不同子类实现不同包装方法
*/
@Override
void packageCourse() {
System.out.println("后端包装方法实现");
}
}
前端课程子类:
package com.geely.design.pattern.behavioral.templatemethod; public class FECourse extends ACourse{
/**
* 不同子类实现不同包装方法
*/
@Override
void packageCourse() {
System.out.println("提供课程前端代码");
System.out.println("提供课程图片素材");
}
}
课程类:
package com.geely.design.pattern.behavioral.templatemethod; /**
* 制作抽象类 课程类,用于被其他类继承
*/
public abstract class ACourse { /**
* 整合课程 的方法,
* 该流程是固定的,子类不能重写
*/
protected final void makeCourse(){
makePPT();
makeVideo();
if(needMakeArticle()){
makeArticle();
}
packageCourse();
}
/**
* 制作PPT 方法
* 目的:如果想要每个子类都不能重写该方法,就用final修饰
* 原因:每个子类都必须有制作PPT的方法
*/
final void makePPT(){
System.out.println("开始制作PPT");
} /**
* 同上
*/
final void makeVideo(){
System.out.println("制作课程视频");
} /**
* 制作手记方法
* 该方法不可被重写
* 有的课程需要制作,有的课程不需要
*/
final void makeArticle(){
System.out.println("编写手记");
} /**
* 添加钩子方法
* 该方法可被子类重写,用于判断子类是否需要制作手记
* @return
*/
protected boolean needMakeArticle(){
return false;
} /**
* 包装课程方法,
* 目的:不同的课程,包装的素材也不一样,所以声明抽象的,子类可以重写
*/
abstract void packageCourse();
}
测试类:
package com.geely.design.pattern.behavioral.templatemethod; public class Test {
public static void main(String [] args){ System.out.println("=======================后端课程开始");
ACourse aCourse1 = new DesignPatternCourse();
aCourse1.makeCourse();
System.out.println("=======================后端课程结束"); System.out.println("=======================前端课程开始");
ACourse aCourse2 = new FECourse();
aCourse2.makeCourse();
System.out.println("=======================前端课程结束");
}
}
打印日志:
=======================后端课程开始
开始制作PPT
制作课程视频
编写手记
后端包装方法实现
=======================后端课程结束
=======================前端课程开始
开始制作PPT
制作课程视频
提供课程前端代码
提供课程图片素材
=======================前端课程结束 Process finished with exit code 0
1.3 代码演练3(前端有多个子类,有得需要写手记,有得不需要写,如何实现?)
解决方案:
将是否需要手记这个字段开放给应用层,这样使用起来更加灵活
uml类图:
重点看:
测试类和前端子类
测试类:
package com.geely.design.pattern.behavioral.templatemethod; public class Test {
public static void main(String [] args){ /* System.out.println("=======================后端课程开始");
ACourse aCourse1 = new DesignPatternCourse();
aCourse1.makeCourse();
System.out.println("=======================后端课程结束");*/ System.out.println("=======================前端课程开始");
ACourse aCourse2 = new FECourse(true);
aCourse2.makeCourse();
System.out.println("=======================前端课程结束"); System.out.println("=======================前端课程开始");
ACourse aCourse3 = new FECourse(false);
aCourse3.makeCourse();
System.out.println("=======================前端课程结束");
}
}
前端子类:
package com.geely.design.pattern.behavioral.templatemethod; public class FECourse extends ACourse{
boolean bNeedMakeArticleFlag = false; /**
* 用注入的方式 将该字段传入
* @param bNeedMakeArticleFlag
*/
public FECourse(boolean bNeedMakeArticleFlag) {
this.bNeedMakeArticleFlag = bNeedMakeArticleFlag;
} /**
* 不同子类实现不同包装方法
*/
@Override
protected boolean needMakeArticle() {
return this.bNeedMakeArticleFlag;
} @Override
void packageCourse() {
System.out.println("提供课程前端代码");
System.out.println("提供课程图片素材");
}
}
后端子类:
package com.geely.design.pattern.behavioral.templatemethod; /**
* 设计模式课程,
* 业务场景:不用编写手记
*/
public class DesignPatternCourse extends ACourse{
/**
* 钩子方法,后端课程加入编写手记方法
* @return
*/
@Override
protected boolean needMakeArticle() {
return true;
} /**
* 不同子类实现不同包装方法
*/
@Override
void packageCourse() {
System.out.println("后端包装方法实现");
}
}
课程类:
package com.geely.design.pattern.behavioral.templatemethod; /**
* 制作抽象类 课程类,用于被其他类继承
*/
public abstract class ACourse { /**
* 整合课程 的方法,
* 该流程是固定的,子类不能重写
*/
protected final void makeCourse(){
makePPT();
makeVideo();
if(needMakeArticle()){
makeArticle();
}
packageCourse();
}
/**
* 制作PPT 方法
* 目的:如果想要每个子类都不能重写该方法,就用final修饰
* 原因:每个子类都必须有制作PPT的方法
*/
final void makePPT(){
System.out.println("开始制作PPT");
} /**
* 同上
*/
final void makeVideo(){
System.out.println("制作课程视频");
} /**
* 制作手记方法
* 该方法不可被重写
* 有的课程需要制作,有的课程不需要
*/
final void makeArticle(){
System.out.println("编写手记");
} /**
* 添加钩子方法
* 该方法可被子类重写,用于判断子类是否需要制作手记
* @return
*/
protected boolean needMakeArticle(){
return false;
} /**
* 包装课程方法,
* 目的:不同的课程,包装的素材也不一样,所以声明抽象的,子类可以重写
*/
abstract void packageCourse();
}
打印结果:
=======================前端课程开始
开始制作PPT
制作课程视频
编写手记
提供课程前端代码
提供课程图片素材
=======================前端课程结束
=======================前端课程开始
开始制作PPT
制作课程视频
提供课程前端代码
提供课程图片素材
=======================前端课程结束 Process finished with exit code 0
设计模式课程 设计模式精讲 17-2 模板方法模式coding的更多相关文章
- 设计模式课程 设计模式精讲 13-2 享元模式coding
1 代码演练 1.1 代码演练1 1 代码演练 1.1 代码演练1 需求: 每周由随机部门经历做报告: 重点关注: a 该案例是单例模式和享元模式共同使用 b 外部传入的department是外部状态 ...
- 设计模式课程 设计模式精讲 11-2 装饰者模式coding
1 代码演练 1.1 代码演练1(未使用装饰者模式) 1.2 代码演练2(使用装饰者模式) 1 代码演练 1.1 代码演练1(未使用装饰者模式) 需求: 大妈下班卖煎饼,加一个鸡蛋加一元,一个火腿两元 ...
- 设计模式课程 设计模式精讲 7-2 建造者模式Coding
1 代码演练 1.1 建造者模式演练 1.2 静态内部类演练建造者模式(链式调用) 1 代码演练 1.1 建造者模式演练 需求: 根据讲师提供的课程名称,课程ppt,课程视频,课程手记,课程问答 制作 ...
- CSharp设计模式读书笔记(23):模板方法模式(学习难度:★★☆☆☆,使用频率:★★★☆☆)
模板方法模式:定义一个操作中算法的框架,而将一些步骤延迟到子类中.模板方法模式使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤. 模式角色与结构: 实现代码: using System; ...
- javascript设计模式(张容铭)学习笔记 - 照猫画虎-模板方法模式
模板方法模式(Template Method):父类中定义一组操作算法骨架,而降一些实现步骤延迟到子类中,使得子类可以不改变父类的算法结构的同时可重新定义算法中某些实现步骤. 项目经理体验了各个页面的 ...
- 设计模式课程 设计模式精讲 6-2 抽象工厂coding
1 代码讲解 1.1 抽象工厂优点 1.2 抽象工厂缺点 1.3 为何有产品族的业务场景宜用抽象工厂设计模式?而不是工厂设计模式? 2 代码演练 2.1 抽象工厂代码演练 1 代码讲解 1.1 抽象工 ...
- 设计模式课程 设计模式精讲 18-2 迭代器模式coding
1 代码演练 1.1 代码演练1(迭代器模式演练) 1.2 代码使用场景 1 代码演练 1.1 代码演练1(迭代器模式演练) 需求: 课程管理:需要实现课程可进行增添,删除,并能够打印出课程列表. u ...
- 设计模式课程 设计模式精讲 5-2 工厂方法coding
1 课堂讲义 1.1 产品等级和产品簇 2 代码演练 2.1 工厂方法代码演练 1 课堂讲义 1.1 产品等级和产品簇 工厂方法是为了解决同一产品等级的业务抽象问题 抽象工厂方法是为了解决同一产品簇的 ...
- 设计模式课程 设计模式精讲 22-2 备忘录模式coding
1 代码演练 1.1 代码演练1 1 代码演练 1.1 代码演练1 需求: 网站笔记需要存储快照,能实现回退的功能. 注意: a 设计的时候,可以分为笔记类,笔记快照类和 笔记快照管理类 三个类. ...
随机推荐
- Ubuntu16 nginx 配置 Let's Encrypt 免费ssl
每篇一句 Some of us get dipped in flat, some in satin, some in gloss. But every once in a while you find ...
- 用vscode写c/c++
用vscode写c/c++ 1. 安装wsl windows下安装linux(ubuntu) 2. 打开设置 3. 输入run code 随便找一个地方粘贴,会出现一大段代码 4. 把c对应的代码修改 ...
- PHP转换oracle数据库的date类型
今天圣诞节啊,圣诞节快乐啊! 最近遇到一个很纠结的事,就是我在plsql里面查的是这样的,很正常, 但是我用程序查出来就是这样的,啊啊啊,真是崩溃啊 但是我传数据需要上面那种格式,而且我对oracle ...
- dockerfile的编写参数
注意细节 “#”号开头是注释 ,指令不区分大小写,顺序执行 FROM 指定基础镜像:注意必须是文件里第一个非注释行 ENV name 值 设置变量,注意没有=号 变量引用 ${name:-chenxi ...
- Java web 会话技术 cookie与session
一.会话 会话可简单理解为:用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话. 会话过程中要解决的一些问题 每个用户在使用浏览器与服务器进行会话的过程 ...
- CSS中 - display: inline-block
参考 https://stackoverflow.com/questions/9189810/css-display-inline-vs-inline-block An inline-block el ...
- php学习之始于html——div布局与css控制
关于您的问题:xampp是一个集成的php开发环境,里面包含Apache,mysql等环境,主要充当一个服务器的角色, 其中有文件,数据,路径等,一个网站程序安装之后,都会有一个根目录,根目录下,有其 ...
- Python中Numpy.nonzero()函数
Numpy.nonzero()返回的是数组中,非零元素的位置.如果是二维数组就是描述非零元素在几行几列,三维数组则是描述非零元素在第几组中的第几行第几列. 举例如下: 二维数组: a = np.arr ...
- 吴裕雄 PYTHON 神经网络——TENSORFLOW MNIST读取数据
from tensorflow.examples.tutorials.mnist import input_data mnist = input_data.read_data_sets("E ...
- Cisco AP-Sniffer模式空口抓包
第一步:WLC/AP侧 配置AP为sniffer模式: 配置提交后,AP会重启,并且将不能发出SSID为clients提供服务. 第二步:一旦AP重新加入WLC,配置AP抓取的信道和抓取后的数据包发 ...