@Fox Привет.Я описывал задачу в этой теме https://community.bablosoft.com/topic/27417/вызов-многопоточной-функции
Дело в том,что я не могу вообще никак перевести свой скрипт на многопоток,у меня тупо,что в вызове функции в многопоток,что просто обычный многопоток,выполняет свою работу с данными по очереди,а не одновременно.И это очень сильно бьет по времени,а нужна именно скорость обработки.Все уже готово и скрипт рабочий полностью,но скорость обработки заставила воспользоваться многопотоком.Ранее,подобных проблем не замечал,а сейчас элементарную задачу не могу уже несколько дней решить.
Скрипт очень простой и работает без браузера вообще,в скрипте используется только одно взаимодействие с гет запросом.Пример скрипта я приложил в этой теме(но без запросов),он точно почти такой же,как и основа.
Логика такова:
1)Запускается скрипт (без всяких ресурсов изначально и данных) и создаются два ресурса.
2)Делается запрос на сайт,который обрабатывается в отдельной функции,т.е. обрабатывает полученные строки и записывает в ресурс.
3)Вызывается функция в несколько потоков,которая работает (должна работать) с каждой строкой из созданного ранее ресурса(уникальной)в отдельном потоке.Данные обрабатываются и записываются во второй ранее созданный ресурс.
4)Как только данные обработаны,ресурс переводится в список и список записывается в файл.Более ничего не делается.
-Сперва я думал,что проблема в создаваемых в ходе работы ресурсах,но нет.Создавал изначально ресурсы и то же самое было.
-Потом пробовал брать из файлов значения\потом создавать файлы по ходу и из них брать данные\сохранять напрямую пытался и.т.д
-Возможно думал стоят какие то ограничения из за слабого пк с 4 гб оперативы и взял сервер с 64 гб,но как обрабатывалась строка за 5 минут на моем пк,так же по скорости и на серваке.Ладно, с этим я уже ничего не поделаю из за регулярок в проекте,согласен.Но вот перевести на поток и хотя бы по 10 строк одновременно обрабатывать,очень бы помогло.А сейчас в любом случае,у меня,сколько бы потоков не выставил - работает все равно как один,просто по очереди разный поток берет свои данные(
Счетчик в многопотоке
-
Подскажите как сделать счётчик в многопотоке?
Есть 10 потоков каждый поток отрабатывает n-раз,выводит слово к примеру "банан" как мне сдетать чтобы выводило
Поток:1 банан 1
Поток:2 банан 2
Поток:1 банан 3
и так далее,
Или хотя бы для каждого потока свой счетчик
Поток:1 банан 1
Поток:2 банан 1
Поток:3 банан 1
Поток:1 банан 2
Поток:2 банан 2
Поток:3 банан 2
Думаю такая тема уже была(в поиске сам найти не смог(наверно криворукий)) дай те плс ссылку на пост -
Подскажите как сделать счётчик в многопотоке?
В OnApplicationStart устанавливаешь глобальную переменную, а в потоках уже увеличиваешь эту глобальную переменную.
Или хотя бы для каждого потока свой счетчик
Объявляешь свою переменную в main да увеличиваешь её.
-
А если у меня допустим многопоток, и я хочу получать значения которые отдаёт каждый поток по отдельности, т.е. кол-во выполнений того или иного действия
Установил переменную в начале работы скрипта, и увеличиваешь её после выполнения какого нибудь действия. Всё. Можешь создать сколько угодно таких счётчиков.
-
В OnApplicationStart устанавливаешь глобальную переменную, а в потоках уже увеличиваешь эту глобальную переменную.
Если будет перезагрузка потока то глобальная переменная объявится на 0 опять
Нет, не объявится на 0 опять. Так как OnApplicationStart выполняется один раз при запуске скрипта, до начала работы всех потоков.
-
Я не обьявлял ее в Onapplicationstart
Зря..
логика и не сработает, ведь эта функция выполняется до всех потоков, а значит каждый поток получит по нулю в ней
Я засыпаю и не могу переварить смысл вашей фразы.. Оставлю алгоритм необходимых действий:
- Устанавливаете глобальную переменную счётчика в Onapplicationstart
- Увеличиваете её в потоках в нужных местах действием увеличить глобальную переменную
- Всё
-
@seoshnek said in Счетчик в многопотоке:
ведь эта функция выполняется до всех потоков, а значит каждый поток получит по нулю в ней. Верно?
Каждый поток из Onapplicationstart ничего не получит. Каждый поток в свою очередь обратиться к глобальной переменной и получит значение из неё. Глобальная переменная хранится вне потоков и любых функций.
А смысл Onapplicationstart в том, что действия в ней выполняются один раз до старта потоков, хоть он 1, хоть 100.