我正在使用 System.nanoTime() 来测量调用几种方法所需的时间。在每种方法中,我都会做同样的事情来衡量每种方法需要多长时间。最后经过时间的总和应该小于总经过时间,或者我认为。然而,事实并非如此。
例子:
public static void main(String[] args){
long startTime = System.nanoTime();
method1();
method2();
method3();
System.out.println( "Total Time: " + (System.nanoTime() - startTime) / 1000000);
}
private void method1(){
long startTime = System.nanoTime();
//Stuff
System.out.println( "Method 1: " + (System.nanoTime() - startTime) / 1000000);
}
// same for all other methods
在我的情况下,总时间大约为 950 毫秒,但每个经过时间的总和为 1300 毫秒以上。为什么是这样?
编辑:
好的,为了更清楚一点,我在多次写入数组时没有出现这种行为(我只是作为测试做的)。当我这样做时,我得到了非常精确的结果(+-1ms)。
我实际上在做的是:
我将两个非常大的文本文件读入字符串数组(第一个文件中 1000 * ~2000 个字符,第二个文件中 200 * ~100 个字符)。
然后我对读取第一个文件得到的字符串数组进行大量比较,并使用结果来计算一些概率。
EDIT2:我的错误,我在方法中调用方法并总结了那些已经包含在内的时间。没有这些双倍,这一切都加起来了。感谢您清除此问题!