4

考虑到 JMH 的默认使用情况,我想确定 JMH 的测量基于哪种类型的时间:CPU 时间或挂钟。

我尝试查看 JMH 官方示例(https://openjdk.java.net/projects/code-tools/jmh/)、教程(在 Jenkov、Baeldung、Mykong 等),但未能准确找到这些信息(我承认我可能错过了一些关于基准的文档或一般信息)。

例如,在示例 35 ( https://hg.openjdk.java.net/code-tools/jmh/file/99d7b73cf1e3/jmh-samples/src/main/java/org/openjdk/jmh/samples/JMHSample_35_Profilers.java ),我们以输出为例:

        Benchmark                              (type)  Mode  Cnt     Score    Error   Units

          JMHSample_35_Profilers.Maps.test     hashmap  avgt    5  1553.201 ±   6.199   ns/op

          JMHSample_35_Profilers.Maps.test     treemap  avgt    5  5177.065 ± 361.278   ns/op

因此,我想知道 Score 列是使用 Wall-clock time 还是 CPU Time 计算的,以便我可以准确地解释基准测试结果。

4

1 回答 1

0

正如我所担心的那样,我错过了基本信息并糟糕地提出了我的问题,因为挂钟和 CPU 时间不是唯一的选择。我按照 Alexandre Cartapanis 的建议查看了 JMH 的源代码。我发现生成基准的BenchmarkGenerator类依赖于 System.nanoTime()。

此外,根据System.nanoTime() 文档Kevin Bourrillion对另一个问题的回答,我得出的结论是,默认情况下,JMH 根据一些任意但固定的源(就像 System.nanoTime())来测量时间。

于 2019-09-27T23:01:16.907 回答