如何计算方法在Java中的执行时间?

问题

如何获得方法的执行时间?是否有Timer实用程序类用于计算任务所需的时间等等?

Google上的大多数搜索会返回计划线程和任务的计时器的结果,这不是我想要的。


#1 热门回答(941 赞)

总有一种老式的方式:

long startTime = System.nanoTime();
methodToTime();
long endTime = System.nanoTime();

long duration = (endTime - startTime);  //divide by 1000000 to get milliseconds.

#2 热门回答(158 赞)

我顺便回答一下。适用于我。

long startTime = System.currentTimeMillis();

doReallyLongThing();

long endTime = System.currentTimeMillis();

System.out.println("That took " + (endTime - startTime) + " milliseconds");

它运作得很好。分辨率显然只有毫秒,你可以用System.nanoTime()做得更好。两者都存在一些限制(操作系统计划切片等),但这很有效。

几次运行的平均值(越多越好),你会得到一个不错的主意。


#3 热门回答(141 赞)

拜托了伙计们!没人提到Guava那样做(这可以说是很棒):

import com.google.common.base.Stopwatch;

Stopwatch timer = Stopwatch.createStarted();
//method invocation
LOG.info("Method took: " + timer.stop());

好的是,Stopwatch.toString()可以很好地选择测量的时间单位。即如果值很小,它将输出38 ns,如果它很长,它将显示5m 3s

更好的:

Stopwatch timer = Stopwatch.createUnstarted();
for (...) {
   timer.start();
   methodToTrackTimeFor();
   timer.stop();
   methodNotToTrackTimeFor();
}
LOG.info("Method took: " + timer);

注意:Google Guava需要Java 1.6