总有一种老式的方式:
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()做得更好。两者都存在一些限制(操作系统计划切片等),但这很有效。
几次运行的平均值(越多越好),你会得到一个不错的主意。
拜托了伙计们!没有人提到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+