一、 应用场景
在日常开发中,我们经常需要测量某一段代码、一个算法或者一个方法的执行耗时(秒数),以便进行性能优化。为了让这个“时间计数器”能够通用,去测试任何不同的代码块,我们可以借助Java 的匿名内部类来实现。
二、 核心设计思路
定义接口(Task):创建一个通用的任务接口,里面包含一个抽象方法
execute(),用来放置具体的业务代码。编写工具方法(computeTime):该方法接收
Task接口作为参数。在方法内部:在调用前利用
System.currentTimeMillis()记录开始时间。执行
task.execute()。在调用后再次记录结束时间。
两者相减并除以
1000.0,计算出消耗的秒数。
匿名内部类调用:在
main方法中调用工具方法时,直接 new 一个Task接口的匿名内部类,动态地将需要测试的耗时代码写在里面。
三、 完整实现源码
public class test2 {
// 1. 定义一个任务接口
interface Task {
void execute();
}
// 2. 编写计算执行时间的方法
public static void computeTime(Task task) {
long startTime = System.currentTimeMillis();
// 执行具体的任务
task.execute();
long endTime = System.currentTimeMillis();
// 计算耗时(毫秒),并转换为秒
double durationInSeconds = (endTime - startTime) / 1000.0;
System.out.println("\n--------------------------------");
System.out.printf("方法执行完毕,总共耗时: %.3f 秒\n", durationInSeconds);
System.out.println("--------------------------------");
}
public static void main(String[] args) {
// 3. 使用匿名内部类来传递具体的“应用场景”或方法
computeTime(new Task() {
@Override
public void execute() {
System.out.println("正在执行某个耗时的方法...");
try {
// 模拟方法执行耗时,让线程休眠 2.5 秒
Thread.sleep(2500);
} catch (InterruptedException e) {
e.printStackTrace();
}
// 模拟循环操作
long sum = 0;
for (int i = 0; i < 1000000; i++) {
sum += i;
}
System.out.println("耗时方法执行结束,计算结果 sum = " + sum);
}
});
}
}
四、 运行结果展示