如何准确计算Java程序从/向文件写入或读取多个字节所需的时间?
准确测量时间非常重要。 (时间应该由程序本身计算)。
答案 0 :(得分:16)
标准习语是:
long startTime = System.nanoTime();
doSomething();
long elapsedTime = System.nanoTime() - startTime;
答案 1 :(得分:5)
未经测试,但有类似的内容:
long delta = System.nanoTime();
try {
// do your stuff
} finally {
delta = System.nanoTime() - delta;
}
答案 2 :(得分:2)
这里有一个代码示例:
http://www.goldb.org/stopwatchjava.html
/*
Copyright (c) 2005, Corey Goldberg
StopWatch.java is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
*/
public class StopWatch {
private long startTime = 0;
private long stopTime = 0;
private boolean running = false;
public void start() {
this.startTime = System.currentTimeMillis();
this.running = true;
}
public void stop() {
this.stopTime = System.currentTimeMillis();
this.running = false;
}
//elaspsed time in milliseconds
public long getElapsedTime() {
long elapsed;
if (running) {
elapsed = (System.currentTimeMillis() - startTime);
}
else {
elapsed = (stopTime - startTime);
}
return elapsed;
}
//elaspsed time in seconds
public long getElapsedTimeSecs() {
long elapsed;
if (running) {
elapsed = ((System.currentTimeMillis() - startTime) / 1000);
}
else {
elapsed = ((stopTime - startTime) / 1000);
}
return elapsed;
}
//sample usage
public static void main(String[] args) {
StopWatch s = new StopWatch();
s.start();
//code you want to time goes here
s.stop();
System.out.println("elapsed time in milliseconds: " + s.getElapsedTime());
}
}
答案 3 :(得分:2)
我这样做的方法就是在一个循环中运行它很多次。就像你运行它1000次并计时一样,这给你毫秒。运行它1,000,000次,它给你微秒。
如果你也想知道为什么它会花费多长时间,你可以在它运行时暂停一些次数(比如10次),这会告诉你它在做什么以及为什么。
答案 4 :(得分:1)
get System.xxx方法的问题在于该方法本身需要几毫秒的时间来计算。通常“接受”的方式是运行测试几万次并计算平均值。
此外,根据您的操作系统,还有一些名为time granularity的内容(Windows的示例)。这是您的操作系统可以计算的最短时间。在一些操作系统上它是一毫秒,在另一些操作系统上它是一个纳秒。它可能与您的情况有关,也可能不相关。