![]() |
Модераторы: bsa |
![]() ![]() ![]() |
|
chetl |
|
||||
![]() Новичок Профиль Группа: Участник Сообщений: 37 Регистрация: 12.9.2007 Репутация: нет Всего: нет |
Есть папка с 40 тысячами файлов. Необходимо считать их несколькими потоками. То как вижу реализацию программы я это сначала найти все 40 тыщ файлов, записать их адреса в вектор, а потом передать работу с ними четырем потокам, но хотелось бы распараллелить эту работу, если у меня 4 потока то для их работы нужно только 4 файла а не все 40 тыщ. Как сделать чтобы программа параллельно искала файлы и в тоже время найденные файлы обрабатывали потоки, а не сначала искать все файлы а потом их обрабатывать?
Вот например чтение одного файла одним потоком
вот поиск файлов в папке
Это сообщение отредактировал(а) chetl - 28.10.2016, 10:04 |
||||
|
|||||
xvr |
|
|||
Эксперт ![]() ![]() ![]() ![]() Профиль Группа: Комодератор Сообщений: 7046 Регистрация: 28.8.2007 Где: Дублин, Ирландия Репутация: 35 Всего: 223 |
Делаете очередь (с блокировками по чтению), далее запускаете ваши 4 потока, которые читают из очереди по 1 элементу (имя файла) и обрабатывают. И последний (точнее первый) поток (основная программа) занимается сканированием папки и складыванием имен файлов в очередь.
Сама очередь выглядит как то так:
|
|||
|
||||
chetl |
|
|||
![]() Новичок Профиль Группа: Участник Сообщений: 37 Регистрация: 12.9.2007 Репутация: нет Всего: нет |
Разобрался сам написав свой код. Реализовал предложенную идею с потокобезопасными очередями.
Выглядит это так:
Это сообщение отредактировал(а) chetl - 29.10.2016, 07:23 |
|||
|
||||
![]() ![]() ![]() |
Правила форума "C/C++: Для новичков" | |
|
Запрещается! 1. Публиковать ссылки на вскрытые компоненты 2. Обсуждать взлом компонентов и делиться вскрытыми компонентами
Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, JackYF, bsa. |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | C/C++: Для новичков | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |