@Fox Привет.Я описывал задачу в этой теме https://community.bablosoft.com/topic/27417/вызов-многопоточной-функции
Дело в том,что я не могу вообще никак перевести свой скрипт на многопоток,у меня тупо,что в вызове функции в многопоток,что просто обычный многопоток,выполняет свою работу с данными по очереди,а не одновременно.И это очень сильно бьет по времени,а нужна именно скорость обработки.Все уже готово и скрипт рабочий полностью,но скорость обработки заставила воспользоваться многопотоком.Ранее,подобных проблем не замечал,а сейчас элементарную задачу не могу уже несколько дней решить.
Скрипт очень простой и работает без браузера вообще,в скрипте используется только одно взаимодействие с гет запросом.Пример скрипта я приложил в этой теме(но без запросов),он точно почти такой же,как и основа.
Логика такова:
1)Запускается скрипт (без всяких ресурсов изначально и данных) и создаются два ресурса.
2)Делается запрос на сайт,который обрабатывается в отдельной функции,т.е. обрабатывает полученные строки и записывает в ресурс.
3)Вызывается функция в несколько потоков,которая работает (должна работать) с каждой строкой из созданного ранее ресурса(уникальной)в отдельном потоке.Данные обрабатываются и записываются во второй ранее созданный ресурс.
4)Как только данные обработаны,ресурс переводится в список и список записывается в файл.Более ничего не делается.
-Сперва я думал,что проблема в создаваемых в ходе работы ресурсах,но нет.Создавал изначально ресурсы и то же самое было.
-Потом пробовал брать из файлов значения\потом создавать файлы по ходу и из них брать данные\сохранять напрямую пытался и.т.д
-Возможно думал стоят какие то ограничения из за слабого пк с 4 гб оперативы и взял сервер с 64 гб,но как обрабатывалась строка за 5 минут на моем пк,так же по скорости и на серваке.Ладно, с этим я уже ничего не поделаю из за регулярок в проекте,согласен.Но вот перевести на поток и хотя бы по 10 строк одновременно обрабатывать,очень бы помогло.А сейчас в любом случае,у меня,сколько бы потоков не выставил - работает все равно как один,просто по очереди разный поток берет свои данные(
Проблема получение количества элементов в ресурсе
-
@FastSpace Тестовый скрипт запускал? Я не удаляю его вручную, он сам удаляется после использования. И перезагрузить ресурс, загружает его заново из файла - это тут вообще не причем.
-
@Denis_krsk Да, странное поведение, сперва подумал, что виноват for, писал про [[CYCLE_INDEX]] ранее. Но убрав цикл совсем:

наблюдаю точно такую же картину[16:16:09] Поток №1 : Количество 3 [16:16:09] Поток №1 : 1 [16:16:09] Поток №1 : Количество 3 [16:16:09] Поток №1 : 2 [16:16:09] Поток №1 : Количество 2 [16:16:09] Поток №1 : 3 [16:16:09] Поток №1 : Количество 1 [16:16:09] Поток №1 : Все данные были обработаны для test //вылет скрипта [16:16:15] Поток №1 : Количество 0 //в ручную выполнил командуВот тестовый скрипт без цилка.
-
@Denis_krsk Хуже, смотри, решил посмотреть с обычным массивом как обстоят дела..
length - Длина массива: число, на единицу превосходящее максимальный индекс массива.
Создал я список с тремя элементами, [[NEW_LIST]].length выдаёт 3Создал цикл от 0 до [[NEW_LIST]].length, цикл должен выполнить действие 4 раза, от 0 до 3. Но проходит только !две! итерации.
Изменил цикл, сделал от 1 до [[NEW_LIST]].length, цикл должен был пройти 3 раза, от 1 до 3, но он опять проходит только !две! итерации.При том, что если цифрами указать от 1 до 3, то пройдёт 3 итерации.
Вот тестовый скрипт.
-
Тоесть вот это значение [[NEW_LIST]].length на каждой итерации будет уменьшаться. Это частая ошибка элементы массива в цикле удаляют.
-
@Denis_krsk А я думал, что определяется for при начале цикла, а не при каждой итерации.
У тебя же такая же выходит ошибка, удаляешь из массива (объекта).
Заметил, что если использовать лог перед проверкой, срабатывает правильно:

Вот тестовый скрипт
-
Более того ты же сам провел эксперимент вообще без цикла!
-
У меня не такая.
@Denis_krsk Вот твой скрипт с 10 элементами. Доходит только до 6.
Я получается вывожу количество, потом беру элемент потом опять вывожу количество и на первых двух этерациях получается одинаковый результат
Вот такой вариант работает нормально

Вот скрипт
Но поведение всё равно странное.. -
@Fox Кстати твой вариант с костылем оканчивается ошибкой вот скрипт твой только вместо [[NEW_LIST]].length цифры 0_1526737103463_1526736087699-315-test.xml
-
@Denis_krsk
суть проблемы которую я изложил была именно в неправильном количестве.
Да, и она решается если ещё раз обратится к ресурсу:

[18:35:26] Поток №1 : Количество 10 [18:35:28] Поток №1 : 1 [18:35:29] Поток №1 : Количество 9 [18:35:30] Поток №1 : 2 [18:35:31] Поток №1 : Количество 8 [18:35:32] Поток №1 : 3