ここ数日、並列処理について少し学んでいて、この例に出くわしました。
次のような順次 for ループを並べて配置します。
private static void NoParallelTest()
{
int[] nums = Enumerable.Range(0, 1000000).ToArray();
long total = 0;
var watch = Stopwatch.StartNew();
for (int i = 0; i < nums.Length; i++)
{
total += nums[i];
}
Console.WriteLine("NoParallel");
Console.WriteLine(watch.ElapsedMilliseconds);
Console.WriteLine("The total is {0}", total);
}
NoParallel メソッドが、サイトで提供されている並列の例よりもはるかに速く終了したことに驚きました。
私はi5 PCを持っています。
パラレル方式の方が早く終わると本気で思っていました。
これについて合理的な説明はありますか?多分私は何かを誤解しましたか?