![]() |
Модераторы: korob2001, ginnie |
![]() ![]() ![]() |
|
systemIV |
|
|||
Бывалый ![]() Профиль Группа: Участник Сообщений: 155 Регистрация: 28.3.2011 Репутация: нет Всего: -1 |
Здравствуйте!
Уже не знаю где искать информацию. Решил изучить многопоточноть. До этого опыта ни на одном языке - не было. Основная задача: Брать массив элементов, скажем там 1000 элементов. Обрабатывать в определенное кол-во потоков. Более подробно: Есть файл со списком доменов. Я его открываю и преобразую каждую строку в элемент массива. Есть функция-обработчик, которая заходит на данный домен и проверяет код ответа. Если ответ = 200, выводит его в консоль. Не знаю как это всё раскидать по потокам, что бы скажем я поставил 10 потоков, и скрипт обрабатывал одновременно 10 доменов. Так же если один из доменов проверился раньше других - не ждать пока все домены проверятся, а сразу в данный поток отправлять новый домен. Вообщем нужно как-то отслеживать завершенные потоки и добавлять постоянно новые, что бы всегда работало ровно 10 потоков. Если у кого ни будь есть пример, или скажем можете на коленке написать - буду признателен! Спасибо. |
|||
|
||||
infarch |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 526 Регистрация: 13.3.2009 Репутация: нет Всего: 1 |
В дотнете не стоит создавать потоки вручную. Там другая концепция: вы создаете таски, а система их автоматически раскидывает по пулу потоков. В вашем случае можно попробовать вот это: https://msdn.microsoft.com/ru-ru/library/dd...=vs.110%29.aspx . Для ограничения колличества паралельно выполняемых задач можно использовать https://msdn.microsoft.com/ru-ru/library/sy...=vs.110%29.aspx
|
|||
|
||||
infarch |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 526 Регистрация: 13.3.2009 Репутация: нет Всего: 1 |
Ой, извиняюсь ) Чего-то я дотнет вспомнил вместо перла )
Тогда, создайте нужное колличество потоков, а массив расшарьте между ними с помощью Thread::Queue |
|||
|
||||
Pfailed |
|
|||
Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 933 Регистрация: 19.7.2009 Репутация: 22 Всего: 39 |
Делаешь массив :shared. Создаёшь 10 потоков. В каждом бесконечный цикл с условием выхода из него если массив стал пустым. В итерации делаешь shift массива и обрабатываешь значение.
Полезные ссылки: https://metacpan.org/pod/threads https://metacpan.org/pod/threads::shared http://perldoc.perl.org/functions/lock.html |
|||
|
||||
![]() ![]() ![]() |
Правила форума "Perl" | |
|
Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, korob2001, sharq. |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Perl: Общие вопросы | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |