模板设计模式
- 一、引入
- 二、改进
一、引入
需求
① 有多个类,完成不同的任务 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