模板设计模式 计算代码的执行时间

模板的设计模式

  • 模板:定好了框架,格式,结构。集体的内容需要使用者来填写

  • 在开发中,遇到这样的情况;当解决某个问题的时候,总体的代码的结构是确定的,步骤也是确定的,只是其中的一小步的具体的步骤不确定,那么我们可以把这个不确定的步骤设计为抽象的方法,让使用者实现它

案例

编写一个类,他具有一个功能,可以计算“任意”一段代码的运行时间。

步骤:
(1)获取开始的时间start
(2)执行XXX代码
(3)获取结束的时间end
(4)计算时间差(end- start)

  • 提示:System.currentTimeMillis();获取系统的当前的时间,距离1970-1-1,零点的毫秒数
public class TestTemplate {
	public static void main(String[] args) {
		// 看1-100000的运行的时间
		MyCalTime m = new MyCalTime();
		long time = m.getTime();
		System.out.println("耗时:" + time + "毫秒");

		OtherCalTime o = new OtherCalTime();
		long time2 = o.getTime();
		System.out.println("耗时:" + time2 + "毫秒");
	}
}

abstract class CalTime {
	public long getTime() {
		// (1)获取开始的时间start
		long star = System.currentTimeMillis();

		// (2)执行XXX代码
		doWork();

		// (3)获取结束的时间end
		long end = System.currentTimeMillis();

		// (4)计算时间差(end- start)
		return end - star;

	}

	protected abstract void doWork();// 代表执行XXX代码

}

class MyCalTime extends CalTime {

	@Override
	protected void doWork() {
		// TODO Auto-generated method stub
		// 1、计算1-100000的累加和
		long sum = 0;
		for (int i = 0; i < 100000; i++) {
			sum += i;
		}
		System.out.println("1-100000的累加和" + sum);
	}

}

class OtherCalTime extends CalTime {

	@Override
	protected void doWork() {
		// 计算长度为位10的数组,用随机数为数组赋值,然后从小到大排序
		Random r = new Random();

		int[] arr = new int[10];

		for (int i = 0; i < arr.length; i++) {
//			arr[i] = r.nextInt();//随机产生int范围类的整数
			arr[i] = r.nextInt(100);// 随机产生[0,100)范围内的一个整数

		}

		// 冒号排序,n-1轮,本题是9轮
		for (int i = 1; i < arr.length; i++) {
			for (int j = 0; j < arr.length - i; j++) {
				if (arr[j] > arr[j + 1]) {
					int temp = arr[j];
					arr[j] = arr[j + 1];
					arr[j + 1] = temp;
				}
			}
		}

		System.out.println(Arrays.toString(arr));

	}

}

示例:

abstract class OrderSettlement{
	public final void settle(){
		System.out.println("创建新订单");
		System.out.println("在订单表插入信息");
		System.out.println("在订单明细表插入信息");
		System.out.println("修改商品的销量和库存量");
		pay();
		System.out.println("修改订单创建为已支付");
	}

	protected abstract void pay() ;
}
class Alipay extends OrderSettlement{

	@Override
	protected void pay() {
		System.out.println("支付宝支付");
	}
	
}
class Wechat extends OrderSettlement{

	@Override
	protected void pay() {
		System.out.println("微信支付");
	}
	
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值