@Fox Привет.Я описывал задачу в этой теме https://community.bablosoft.com/topic/27417/вызов-многопоточной-функции
Дело в том,что я не могу вообще никак перевести свой скрипт на многопоток,у меня тупо,что в вызове функции в многопоток,что просто обычный многопоток,выполняет свою работу с данными по очереди,а не одновременно.И это очень сильно бьет по времени,а нужна именно скорость обработки.Все уже готово и скрипт рабочий полностью,но скорость обработки заставила воспользоваться многопотоком.Ранее,подобных проблем не замечал,а сейчас элементарную задачу не могу уже несколько дней решить.
Скрипт очень простой и работает без браузера вообще,в скрипте используется только одно взаимодействие с гет запросом.Пример скрипта я приложил в этой теме(но без запросов),он точно почти такой же,как и основа.
Логика такова:
1)Запускается скрипт (без всяких ресурсов изначально и данных) и создаются два ресурса.
2)Делается запрос на сайт,который обрабатывается в отдельной функции,т.е. обрабатывает полученные строки и записывает в ресурс.
3)Вызывается функция в несколько потоков,которая работает (должна работать) с каждой строкой из созданного ранее ресурса(уникальной)в отдельном потоке.Данные обрабатываются и записываются во второй ранее созданный ресурс.
4)Как только данные обработаны,ресурс переводится в список и список записывается в файл.Более ничего не делается.
-Сперва я думал,что проблема в создаваемых в ходе работы ресурсах,но нет.Создавал изначально ресурсы и то же самое было.
-Потом пробовал брать из файлов значения\потом создавать файлы по ходу и из них брать данные\сохранять напрямую пытался и.т.д
-Возможно думал стоят какие то ограничения из за слабого пк с 4 гб оперативы и взял сервер с 64 гб,но как обрабатывалась строка за 5 минут на моем пк,так же по скорости и на серваке.Ладно, с этим я уже ничего не поделаю из за регулярок в проекте,согласен.Но вот перевести на поток и хотя бы по 10 строк одновременно обрабатывать,очень бы помогло.А сейчас в любом случае,у меня,сколько бы потоков не выставил - работает все равно как один,просто по очереди разный поток берет свои данные(
Глобальные переменные и многопоток
-
Собственно, решил написать скрипт, посмотрел, что для лучшей работы, стоит реализовать чтобы регистрация и лайкер работали в 1-ом потоке, проверка сообщений во 2-ом, отправка 3 -ем. Во 2 и 3 потоках встроено вечное ожидание. Решил запустить, получил вылет. Начал гадать. Зделал вот такой простой пример использования глобальной переменной, которая была создана и получена из 1-го потока и должна быть использована во 2-ом, после её обозначения, но скрипт крашится и всё.
-
@KoliaPotexin said in Глобальные переменные и многопоток:
Собственно, решил написать скрипт, посмотрел, что для лучшей работы, стоит реализовать чтобы регистрация и лайкер работали в 1-ом потоке, проверка сообщений во 2-ом, отправка 3 -ем. Во 2 и 3 потоках встроено вечное ожидание до изменения получения данных в глобальную переменную, после они начинают работать. Решил запустить, получил вылет. Начал гадать. Зделал вот такой простой пример использования глобальной переменной, которая была создана и получена из 1-го потока и должна быть использована во 2-ом, после её обозначения, но скрипт крашится и всё.
Добавь сон в ожидание
-
@KoliaPotexin said in Глобальные переменные и многопоток:
@Fox Спасибо, ожидание помогло как в тестовом скрипте, так и изначальном.
Можно узнать, почему без пауз это конструкция считается не рабочий?Потому что происходит бесконечный цикл без задержки. Это вызывает зависание интерфейса, то есть если подождать, то интерфейс отвиснет когда произойдёт выход из цикла.
-
@KoliaPotexin said in Глобальные переменные и многопоток:
@Fox Забавно, но был либо мгновенный вылет, либо задержка и вылет.
Не помню, это где то в винде настраивается, чтобы приложение не завершалось при зависании
Не знаете ещё хорошие конструкции подходящие к моему шаблону? Заинтересовала возможность давать каждому потоку свою задачу, довольно полезная возможность
Не уверен что это именно полезная возможность. Вы обрисуйте задачу которую хотите решить
-
@KoliaPotexin, @GhostZ said in Несколько потоков - разные функции:
@jjsf, @ghostz said in Specific function for each thread:
@hifive,
Example # 1 splitting threads into 2 functions action_test1.xml.
Example # 2 splitting threads into any number of functions action_test2.xml.Пример №1 разделение потоков на 2 функции
Пример №2 разделение потоков на сколько угодно функций