1

为什么 JIT 编译器不适用于以下代码?

而且每个单独的循环似乎都需要很长时间

(参见我关于执行时间的另一篇文章。简单循环的速度

 public static void main (String[] args) {  
    for (int j = 0; j < 10; j++) {
        float f;

        long start = System.nanoTime();

        for (int i = 0; i < 2000000000; i++) {
            f = i * 0.0001F;
        }
        long end = System.nanoTime();
        long timeToCallNanoTime = System.nanoTime() - end;
        long time = Math.max(0, end - start - timeToCallNanoTime);
        System.out.println("time: " + time + " ns.");
    }

}

结果:

 time: 6639317628 ns.
 time: 6630196045 ns.
 time: 6632583856 ns.
 time: 6617596798 ns.
 time: 6605243858 ns.
 time: 6609097755 ns.
 time: 6627151876 ns.
 time: 6623427381 ns.
 time: 6632506712 ns.
 time: 6615870257 ns.
4

1 回答 1

3

正如您在我对上一个问题的回答中看到的那样,它对我有用。

您很可能使用的是 32 位 Windows 附带的客户端 JVM。客户端 JVM 并没有优化代码以最小化启动时间。我建议你使用默认使用 JVM 的 64 位 JVM,-server它会更积极地优化代码。

顺便说一句,我使用的是 Java 7 update 40。如果你有一个非常旧的 Java 版本,它可能不会优化循环。

于 2013-09-17T12:59:09.180 回答