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