模板设计模式
- 一、引入
- 二、改进
一、引入
需求
① 有多个类,完成不同的任务 job
② 要求统计得到各自完成任务的时间
③ 请编程实现
=>最容易想到的方法,写类,统计时间
AA BB中的 job 方法中是有重复的。
=>改进1:每个类中,提取重复的部分为单独的方法
=>改进2:提取各个类中的重复部分,为抽象类(父类)
public class TestTemplate {
public static void main(String[] args) {
AA aa = new AA();
aa.job();
BB bb = new BB();
bb.job();
}
}
class AA {
//计算任务 1+···
public void job() {
// java.lang包,System类中有currentTimeMillis
// static long currentTimeMillis()
// 返回当前时间(以毫秒为单位)
int num = 0;
long start = System.currentTimeMillis();
for (int i = 0; i < 1000000; i++) {
num += i;
}
long end = System.currentTimeMillis();
System.out.println("AA 执行时间="+(end-start)+"毫秒");
}
}
class BB {
public void job() {
// java.lang包,System类中有currentTimeMillis
// static long currentTimeMillis()
// 返回当前时间(以毫秒为单位)
long num = 0;
long start = System.currentTimeMillis();
for (int i = 0; i < 60000; i++) {
num *= i;
}
long end = System.currentTimeMillis();
System.out.println("BB 执行时间="+(end-start)+"毫秒");
}
}
改进1 :
class X {
public void calculateTime() {
//计算开始时间
job();//不同的类,job不同
//计算结束时间
}
public void job() {
//不同的类,job不同
}
}
二、改进
设计一个抽象类(Template),能完成如下功能:
- 编写方法 calculateTime(),可以计算某段代码的耗时时间。
- 编写抽象方法 job()。
- 编写一个子类Sub迷承抽象类Template,并实现code方法。
- 编写一个测试类TestTemplate,看看是否好用。
AAA aaa = new AAA();
aaa.calTime();
abstract class Template {
public abstract void job();
public void calTime() {
long start = System.currentTimeMillis();
job();//调用了抽象方法
long end = System.currentTimeMillis();
System.out.println("执行时间="+(end-start)+"毫秒");
}
}
//这里因为同个包下类名不能相同
class AAA extends Template {
public void job() {
// AAA的job
}
}
aaa.calTime();执行流程,先找到父类的calTime,在该函数执行的过程中遇见了抽象方法 job,因为是动态绑定,所以会去找本类中的 job,job执行完之后,又回到父类的calTime。
本笔记是对韩顺平老师的Java课程做出的梳理。方便本人和观看者进行复习。
课程请见: https://www.bilibili.com/video/BV1fh411y7R8/?spm_id_from=333.999.0.0&vd_source=ceab44fb5c1365a19cb488ab650bab03