一、 应用场景在日常开发中我们经常需要测量某一段代码、一个算法或者一个方法的执行耗时秒数以便进行性能优化。为了让这个“时间计数器”能够通用去测试任何不同的代码块我们可以借助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() {Overridepublic 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);}});}}四、 运行结果展示