为什么 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.
正如您在我对上一个问题的回答中看到的那样,它对我有用。
您很可能使用的是32位Windows附带的客户端JVM。客户端 JVM 不会对代码进行过多的优化以最大程度地减少启动时间。 我建议您使用 64 位 JVM,它默认使用 -server
JVM,它将更积极地优化代码。
顺便说一句,我使用的是 Java 7 更新 40。 如果你有一个非常旧的Java版本,它可能不会优化循环。