2

我有多个网络请求需要按顺序发生。他们必须等到前一个完成并收到来自服务器的响应。

现在我有一个回调死亡金字塔。有没有更自动化的方法来做到这一点?我尝试了一个,OperationQueue但它不会等待请求完成,然后再前进到下一个请求,即使它设置为一次执行一个请求。

对于它的价值,.save是对 CloudKit 的网络请求。没有像其他 CloudKit 操作那样的 CloudKit 订阅队列。

self.privateDB.save(subscriptions[0]){ savedSubscription, error in
  //Request 1 is done
  self.privateDB.save(subscriptions[1]){ savedSubscription, error in
    //Request 2 is done
    self.privateDB.save(subscriptions[2]){ savedSubscription, error in
      //All 3 requests are done
    }
  }
}

我试过了DispatchGroup,但这似乎不起作用。在等待响应之前,所有请求似乎都已触发。

let group = DispatchGroup()

//Create a subscription for every record type
for subscription in subscriptions{
  group.enter()
  //...
  self.privateDB.save(subscription){ savedSubscription, error in
    group.leave()
  }    
}
group.wait()

有任何想法吗?

4

2 回答 2

1

您应该能够创建一个或多个CKModifySubscriptionsOperation来保存订阅,然后用于CKDatabase.add()运行它们。如果您需要它们按顺序运行,请设置它们之间的依赖关系以确保它们按顺序运行:

let subscriptionOp1 = CKModifySubscriptionsOperation(subscriptionsToSave: subscriptions[0], subscriptionsToDelete: nil)
let subscriptionOp2 = CKModifySubscriptionsOperation(subscriptionsToSave: subscriptions[1], subscriptionsToDelete: nil)
let subscriptionOp3 = CKModifySubscriptionsOperation(subscriptionsToSave: subscriptions[2], subscriptionsToDelete: nil)

subscriptionOp2.addDependency(subscriptionOp1)
subscriptionOp3.addDependency(subscriptionOp2)

database.add(subscriptionOp1)
database.add(subscriptionOp2)
database.add(subscriptionOp3)
于 2017-09-07T16:32:42.450 回答
1

尝试使用信号量使它们同步。

  1. 创建信号量

    var semaphore = dispatch_semaphore_create(0)

  2. 等待第一次 api 调用完成

    dispatch_semaphore_wait(信号量,DISPATCH_TIME_FOREVER)

  3. 在第一个 api 完成时发出信号量。

    dispatch_semaphore_signal(信号量)

前任 :

var semaphore = dispatch_semaphore_create(0) self.privateDB.save(subscriptions[0]){ savedSubscription, dispatch_semaphore_signal(semaphore) 错误 } dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER) self.privateDB.save(subscriptions[1]){ savedSubscription, 错误}

于 2017-09-07T06:27:31.590 回答