процессе обработки происходят долгие и сложные операции в том числе с несколькими походави в REST API, собственно вопрос как сделать так что коллекция обрабатывалась последовательно, то есть обработка следующего элемента запускалась только после того как по предыдущему вся цепочка вызовов прошла либо случилась ошибка?
PS: В той же Scala есть Future которые можно собирать в цепочку, в Swift всё идет через callback и я не могу сообразить как мне не отпускать итератор на следующий цикл до завершения всех callback-ов
https://stackoverflow.com/a/54844032/4742680
Посмотрел, но чстно говоря не понял чем Operations мне поможет, у меня ведь не просто код который выполняется, а код который выполняется и в итоге уходит в REST запрос, то есть в момент вызова REST alamofire уходит в асинхрон и управление порядком исполнения возвращается к основному треду выполнения. То есть у меня проблема что нужно последовательно вызвать N функций результат которых придет в callback и после того как выполнится последний callback отдать управление исполнением циклу по коллекции
есть массив со всеми элементами, для каждого элемента есть понятие выполнено/ошибка запускаешь выполнение задач для первого элемента когда он окончен ставишь соответствующий флаг и запускаешь функцию nextElement() и он проходит по массиву и берет элемент который еще без соответсвующего флага ну как то так
NsoperationQueue как раз выполняют данную функцию. делаешь очередь указываешь какее выполнять и закидываешь таски туда.
Обсуждают сегодня