使用匿名内部类优雅地计算方法执行时间
2026/6/20 1:29:07 网站建设 项目流程

一、 应用场景

在日常开发中,我们经常需要测量某一段代码、一个算法或者一个方法的执行耗时(秒数),以便进行性能优化。为了让这个“时间计数器”能够通用,去测试任何不同的代码块,我们可以借助Java 的匿名内部类来实现。

二、 核心设计思路

  1. 定义接口(Task):创建一个通用的任务接口,里面包含一个抽象方法execute(),用来放置具体的业务代码。

  2. 编写工具方法(computeTime):该方法接收Task接口作为参数。在方法内部:

    • 在调用前利用System.currentTimeMillis()记录开始时间。

    • 执行task.execute()

    • 在调用后再次记录结束时间。

    • 两者相减并除以1000.0,计算出消耗的秒数。

  3. 匿名内部类调用:在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);
}
});

}
}

四、 运行结果展示

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询