如何在Java中对方法的执行进行计时?
2022-08-31 03:59:32
- 如何获取方法的执行时间?
- 是否有实用程序类用于确定任务需要多长时间等?
Timer
Google上的大多数搜索都会返回计划线程和任务的计时器的结果,这不是我想要的。
Timer
Google上的大多数搜索都会返回计划线程和任务的计时器的结果,这不是我想要的。
总是有老式的方式:
long startTime = System.nanoTime();
methodToTime();
long endTime = System.nanoTime();
long duration = (endTime - startTime); //divide by 1000000 to get milliseconds.
我用简单的答案。为我工作。
long startTime = System.currentTimeMillis();
doReallyLongThing();
long endTime = System.currentTimeMillis();
System.out.println("That took " + (endTime - startTime) + " milliseconds");
它工作得很好。分辨率显然只有毫秒,你可以用System.nanoTime()做得更好。两者都有一些限制(操作系统计划切片等),但这效果很好。
平均几次运行(越多越好),你会得到一个不错的主意。