3

我正在使用带有插件的 Eclipse 来运行 VisualVM。现在 VisualVM 说函数的方法调用总是在 180 毫秒左右返回,而如果我使用手动方法:

long start = System.nanoTime();
searchConnections(bsTree, connectionList);
double elapsedTimeInSec = (System.nanoTime() - start) * 1.0e-6;

我得到大约 50 毫秒!为什么有区别?那么 VisualVM 中的测量值是否错误?我需要对某些项目进行测量,这就是为什么尽可能精确地测量它们很重要。

4

1 回答 1

1

要回答您的问题,由于 JVM 的性质以及它将如何在运行时优化代码,没有一种简单的方法可以知道为什么这些值是不同的。更不用说 System.nanotime() 是一个特定于平台的实现,我不会完全相信它对任何准确的价值。

我更可能相信 VisualVM 的结果而不是内联测量,因为 VisualVM 实际上正在测量它。如果您关心基准测试或想真正专注于获得准确的结果,我建议您使用Caliper等工具来完成此任务。

于 2013-03-11T08:19:28.483 回答