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

-
@itzpvpsher, какой вообще смысл запускать асинхронную функцию столько раз, каждая отдельным кубиком?
-
@Agnest said in Асинхронный вызов функции:
@itzpvpsher, какой вообще смысл запускать асинхронную функцию столько раз, каждая отдельным кубиком?
Не торопите пользователя, возможно он постепенно дойдёт до циклов
:D -
@itzpvpsher said in Асинхронный вызов функции:
@Fox какие циклы, там функия одна, но входящие параметры то разные
Поместите все параметры в список и вызывайте функцию в цикле, аргументы берите из списка по индексу счётчика итераций cycle_index
-
@Fox said in Асинхронный вызов функции:
аргументы
а зачем, если это просто лишние, ненужные действия?
-
@itzpvpsher ну штук пять, может, и лишнее, а если повтор 100 функций делать?





