【发布时间】:2011-11-09 10:43:11
【问题描述】:
Does .NET JIT optimize empty loops away?的后续行动:
下面的程序只是运行一个空循环十亿次并打印出运行时间。我的机器上需要 700 毫秒,我很好奇是否有办法让抖动优化掉空循环。
using System;
namespace ConsoleApplication1 {
class Program {
static void Main() {
var start = DateTime.Now;
for (var i = 0; i < 1000000000; i++) {}
Console.WriteLine((DateTime.Now - start).TotalMilliseconds);
}
}
}
据我所知,答案是否定的,但我不知道是否有我可能没有尝试过的隐藏编译器选项。我确保在发布模式下编译并在没有附加调试器的情况下运行,但仍然需要 700 毫秒来运行这个空循环。我也尝试了 NGEN,得到了相同的结果(尽管我的理解是它应该生成与 JIT 相同的编译代码,对吧?)。但是我以前从未使用过 NGEN,可能是用错了。
似乎这对于 JIT 来说很容易找到并优化掉,但对抖动的一般工作原理知之甚少,我很好奇这种优化是否有特定原因被排除在外。此外,VC++ 编译器似乎确实做了这种优化,所以我想知道为什么会出现这种差异。有什么想法吗?
【问题讨论】:
-
为什么在现实中这对您来说是个问题?如果你有一个空循环,就把它去掉。
-
这与您引用的问题有何不同?
-
这不是一个空循环。它增加了 i 十亿倍。
-
@Dax:那篇文章很糟糕。代码 sn-ps 不做同样的事情(提示:浮点数的操作顺序事项)。你不能说苹果是否比橘子快。
-
这个优化的一个公认不寻常的用例是只包含调试代码的循环,因此在发布版本中是空的。也就是说,让 Debug 代码执行很多次是很奇怪的,因此任何性能影响都会非常小。您还可以通过将循环放入方法并注释该方法来手动创建此优化,以便仅在 Debug 构建中调用它。
标签: c# .net clr jit compiler-optimization