package heima;
/*面对对象,模版方法模式
* 获取一段程序的运行时间
* 获取当前时间:System.currentTimeMillis()
* 当代码完成优化后,就可以解决这类问题。
这种方式,模版方法设计模式。
什么是模版方法呢?
在定义功能时,功能的一部分是确定的,但是有一部分是不确定,而确定的部分在使用不确定的部分,
那么这时就将不确定的部分暴露出去。由该类的子类去完成。
* */
abstract class GetTime{
public final void getTime(){//此处用final,防止子类重写方法,不能再次复用
// 为防止恶意操作,一般模板方法都加上 final 关键词
long start = System.currentTimeMillis();
runcode(); //方法体设计在第16行代码中,这里只调用该方法
long end = System.currentTimeMillis();
System.out.println("毫秒:"+ (end -start));
}
public abstract void runcode();//设计为抽象方法,子类继承中 ,按照实际情况写相应方法{}
}
class SubTime extends GetTime{
public void runcode(){
for(int x=0;x<1000;x++){
System.out.println(x);
}
}
}
public class day0711 {
public static void main(String []args){
SubTime su = new SubTime();//new一个子类的对象,调用父类中的方法getTime
su.getTime();
}
}
运行结果: