Swift 5.6, как поместить асинхронную задачу в очередьIOS

Программируем под IOS
Ответить
Anonymous
 Swift 5.6, как поместить асинхронную задачу в очередь

Сообщение Anonymous »

Предположим, у меня есть этот код
class Duck{

func walk() async {
//do something
print("walk start")
try? await Task.sleep(nanoseconds: UInt64(2e9))
print("walk end")
}

func quack() async {
//do something...
print("quack start")
try? await Task.sleep(nanoseconds: UInt64(2e9))
print("quack end")
}

func fly() async{
//do something
print("fly start")
try? await Task.sleep(nanoseconds: UInt64(2e9))
print("fly end")
}

}

let duck = Duck()

Task{
await duck.walk()
}

Task{
await duck.quack()
}

Task{
await duck.fly()
}

Это будет напечатано
walk start
quack start
fly start
walk end
quack end
fly end

что я понимаю и ожидал. Но что, если я хочу, чтобы эти три задачи выполнялись последовательно? Допустим, каждая задача создается пользователем, нажимающим кнопку. Я хочу, чтобы задачи стояли в очереди в фоновом режиме и запускались одна за другой. Есть ли что-нибудь вроде того, как вы можете поставить DispatchWorkItem в очередь в DispatchQueue, но в версии Task?

Изменить:
Я придумал решение, но не уверен, что это хороший способ его реализации. Поскольку эта реализация потенциально создает многоуровневую каскадную задачу, мне интересно, будет ли риск переполнения стека или утечек памяти?
class TaskQueue{
private var currentTask : Task = Task{}

func dispatch(block:@escaping () async ->Void){

let oldTask = currentTask
currentTask = Task{
_ = await oldTask.value
await block()
}
}
}

taskQueue.dispatch {
await duck.walk()
}
taskQueue.dispatch {
await duck.quack()
}
taskQueue.dispatch {
await duck.fly()
}


Подробнее здесь: https://stackoverflow.com/questions/715 ... to-a-queue
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «IOS»