考虑一下:
必要条件:
//The alphabet from a-z
List<char> letterRange = Enumerable.Range('a', 'z' - 'a' + 1)
.Select(i => (Char)i).ToList(); //97 - 122 + 1 = 26 letters/iterations
标准 foreach:
foreach (var range in letterRange)
{
Console.Write(range + ",");
}
Console.Write("\n");
内置 foreach:
letterRange.ForEach(range => Console.Write(range + ",")); //delegate(char range) works as well
Console.Write("\n");
我试过将它们相互计时,内置的 foreach 最多快 2 倍,这看起来很多。
我用谷歌搜索了一下,但似乎找不到任何答案。
此外,关于:In .NET, which loop runs faster, 'for' or 'foreach'?
for (int i = 0; i < letterRange.Count; i++)
{
Console.Write(letterRange[i] + ",");
}
Console.Write("\n");
据我所知,执行速度并不比标准 foreach 快。
最佳答案
我认为您的基准有缺陷。 Console.Write
是一项 I/O 绑定(bind)任务,它是基准测试中最耗时的部分。这是一个微基准,应该非常小心地进行以获得准确的结果。
这是一个基准:http://diditwith.net/PermaLink,guid,506c0888-8c5f-40e5-9d39-a09e2ebf3a55.aspx (看起来不错,但我自己还没有验证过)。 截至 2015 年 8 月 14 日,该链接似乎已断开
关于c# - 为什么 List<T>.ForEach 比标准 foreach 快?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/744085/