.NET 4.x Parallel.for подсчитать количество элементов в массиве - C#

Узнай цену своей работы

Формулировка задачи:

Собственно необходимо посчитать количество элементов в двумерном массиве удовлетворяющих определенным условиям. Так как сам массив очень большой решил распараллелить задачу.
Листинг программы
  1. public Int64 GetCountDead()
  2. {
  3. Int64 count = 0;
  4. Parallel.For(0, SizeX, x =>
  5. {
  6. for (var y = 0; y < SizeY; y++)
  7. {
  8. if (isDead(_map[x, y]))
  9. {
  10. count++;
  11. }
  12. }
  13. });
  14. return count;
  15. }
Но оно работает не верно, что логично, так как код не потокобезопасен. То есть на одинаковом массиве может выдать как 2050 так и 2428 или 2602 ну итд.. как это написать верно?

Решение задачи: «.NET 4.x Parallel.for подсчитать количество элементов в массиве»

textual
Листинг программы
  1. private readonly Object _thisLock = new Object();
  2. public Int64 GetCountDead()
  3. {
  4. Int64 count = 0;
  5. Parallel.For(0, SizeX, x =>
  6. {
  7. var threadResult = 0;
  8. for (var y = 0; y < SizeY; y++)
  9. {
  10. if (isDead(_map[x, y]))
  11. {
  12. threadResult++;
  13. }
  14. }
  15. lock (_thisLock)
  16. {
  17. count += threadResult;
  18. }
  19. });
  20. return count;
  21. }

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

5   голосов , оценка 4.8 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы