private static async Task<int> SumParallel()
{
var intList = Enumerable.Range(1, 1000_000_000);
int count = intList.Count();
int total = 0;
for(int i = 1; i < 5; i++)
{
int skip = ((i - 1) * count) / 4;
int take = count / 4;
Interlocked.Add(ref total,
await GetSum(intList, skip, take));
}
return total;
}
private static async Task<int> GetSum(IEnumerable<int> list, int skip, int take)
{
return await Task.Run(() =>
{
int temp = 0;
foreach(int n in list.Skip(skip).Take(take))
{
if (n % 2 == 0)
temp -= n;
else
temp += n;
}
return temp;
});
}
Я пытаюсь выполнить задачу с интенсивными вычислениями, просто чтобы попрактиковаться в параллельной библиотеке задач. Итак, я написал этот код. Если я попытаюсь вычислить ту же сумму с помощью Parallel Linq, я увижу, что загрузка ЦП достигнет 100% следующим образом:
int sum = Enumerable.Range(1, 1000_000_000)
.AsParallel()
.Select(i => i % 2 == 0 ? -i : i).Sum();
Код ручных параллельных задач = время 10 секунд, cpu = только 25%
Параллельный код Linq = 18 секунд, cpu = 100% (и все еще занимает 18 секунд)
Linq-код без параллелизма: 14 секунд, только cpu = 25%
Почему это так? Когда я также запускаю 4 потока параллельно, почему загрузка моего процессора не достигает go 100%? Это всего 25%, как в непараллельном коде (всего с одним потоком). Я действительно запускаю 4 потока параллельно или нет?
Мой ноутбук Core i3 - 2 ядра = 4 логических процессора