![]() |
|
|
Регистрация Восстановить пароль |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
![]() |
|
Опции темы | Поиск в этой теме |
![]() |
#1 |
Форумчанин
Регистрация: 20.10.2011
Сообщений: 433
|
![]()
Добрый день Уважаемые, подскажите, как организовать отдельный поток под каждый объект в цикл ?
Хочу сделать вот такую работу: Код:
Код:
Думаю можно ручками прописать выполнение цикла под разные потоки, к примеру: Код:
Последний раз редактировалось L6go1as; 21.04.2014 в 16:06. |
![]() |
![]() |
![]() |
#2 |
Форумчанин
Регистрация: 20.10.2011
Сообщений: 433
|
![]()
Подобрал 2 варианта:
"ручной": Код:
Код:
Код:
Первый вариант работает, но уж больно "в лоб", можно ли как ни будь упростить ? Второй вариант работает тоже, но вот не понятно, насколько это производительный вариант и работает ли он оптимально, и насколько "лучшим" вариантом является ? Использовал ThreadPool.GetAvailableThreads, он мне выдает тысячу доступных потоков и тысячу потоков асинхронного ввода\вывода, насколько я понимаю то система резервирует ресурсы под все эти потоки, не слишком ли дорого для системы ? Последний раз редактировалось L6go1as; 21.04.2014 в 20:08. |
![]() |
![]() |
![]() |
#3 |
Форумчанин
Регистрация: 15.12.2010
Сообщений: 398
|
![]()
Однозначно используйте пул потоков, он даст наибольший прирост производительности и свидёт к минимуму переключения контекстов.
|
![]() |
![]() |
![]() |
#4 | |
Старожил
Регистрация: 28.01.2009
Сообщений: 21,000
|
![]() Цитата:
Хорошо поставленный вопрос это уже половина ответа. | Каков вопрос, таков ответ.
Программа делает то что написал программист, а не то что он хотел. Функции/утилиты ждут в параметрах то что им надо, а не то что вы хотите. |
|
![]() |
![]() |
![]() |
#5 |
Форумчанин
Регистрация: 20.10.2011
Сообщений: 433
|
![]()
Ясно, буду тогда в сторону Пула смотреть, однако пока не удается решить поставленную задачу ...
Код:
Код:
Второй код работает "как надо", однако совершенно не понятно сколько потоков на выполнением трудились, если работает лишь одно, то смысл использовать пул ) Есть ли возможность отследить сколько потоков работает для второго кода ? Или можно ли как нить пофиксить первый, что бы очередность работы сохранялась ? |
![]() |
![]() |
![]() |
#6 |
Форумчанин
Регистрация: 20.10.2011
Сообщений: 433
|
![]()
Хм, в поисках решения дошел до Parallel.For и похоже этот вариант наилучший.
Код:
Код:
|
![]() |
![]() |
![]() |
![]() |
||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
С++ многопоточность | kineziz | Общие вопросы C/C++ | 3 | 11.09.2012 13:20 |
многопоточность | blacktener | Общие вопросы по Java, Java SE, Kotlin | 1 | 25.07.2012 13:18 |
Многопоточность | t2skler | Общие вопросы C/C++ | 4 | 16.04.2012 14:24 |
многопоточность | Freddi Krjuger | Общие вопросы по Java, Java SE, Kotlin | 1 | 15.05.2011 23:46 |
Многопоточность | Dezmont_ | Общие вопросы .NET | 1 | 06.11.2010 18:34 |