foreach
vsを使用した場合のパフォーマンスをテストするために、次のように記述しましたLINQ
。
private class Widget
{
public string Name { get; set; }
}
static void Main(string[] args)
{
List<Widget> widgets = new List<Widget>();
int found = 0;
for (int i = 0; i <= 500000 - 1; i++)
widgets.Add(new Widget() { Name = Guid.NewGuid().ToString() });
DateTime starttime = DateTime.Now;
foreach (Widget w in widgets)
{
if (w.Name.StartsWith("4"))
found += 1;
}
Console.WriteLine(found + " - " + DateTime.Now.Subtract(starttime).Milliseconds + " ms");
starttime = DateTime.Now;
found = widgets.Where(a => a.Name.StartsWith("4")).Count();
Console.WriteLine(found + " - " + DateTime.Now.Subtract(starttime).Milliseconds + " ms");
Console.ReadLine();
}
次のような出力が得られます。
31160 - 116ms 31160 - 95 ミリ秒
すべての実行で、LINQ は foreach よりも約 20% 優れています。LINQ 拡張メソッドが標準の c# を内部で使用していることは、私の理解でした。
では、この場合、なぜ LINQ の方が速いのでしょうか?
編集:
そのため、日時の代わりにストップウォッチを使用するようにコードを変更しても、同じ結果が得られます。最初に LINQ クエリを実行すると、結果は LINQ が foreach よりも約 20% 遅いことを示しています。これは、ある種の JIT ウォームナップの問題である必要があります。私の質問は、テスト ケースで JIT ウォームアップをどのように補正するかです。