[英]Completion handlers and Operation queues
我正在尝试采用以下方法,
let operationQueue = OperationQueue()
operationQueue.maxConcurrentOperationCount = 10
func registerUser(completionHandler: @escaping (Result<Data, Error>) -> Void) -> String {
self.registerClient() { (result) in
switch result {
case .success(let data):
self.downloadUserProfile(data.profiles)
case .failure(let error):
return self.handleError(error)
}
}
}
func downloadUserProfile(urls: [String]) {
for url in urls {
queue.addOperation {
self.client.downloadTask(with: url)
}
}
}
我正在检查是否在那里我可以在所有操作完成时得到通知,然后我可以在那里调用成功处理程序。
我尝试检查建议使用的苹果开发文档
queue.addBarrierBlock {
<#code#>
}
但这仅适用于 iOS 13.0
在 iOS 13 之前,我们会使用依赖项。 声明一个完成操作,然后当您为网络请求创建操作时,您需要将这些操作定义为完成操作的依赖项。
let completionOperation = BlockOperation { ... }
let networkOperation1 = ...
completionOperation.addDependency(networkOperation1)
queue.addOperation(networkOperation1)
let networkOperation2 = ...
completionOperation.addDependency(networkOperation2)
queue.addOperation(networkOperation2)
OperationQueue.main.addOperation(completionOperation)
话虽如此,您应该非常小心您的操作实施。 我是否正确推断downloadTask(with:)
在下载任务启动后立即返回并且不等待请求完成? 在这种情况下,依赖项和障碍都不会按照您想要的方式工作。
在操作中包装网络请求时,您需要确保使用异步Operation
子类(例如https://stackoverflow.com/a/32322851/1271826 )。
iOS 13 之前的方式是观察操作队列的operationCount
属性
var observation : NSKeyValueObservation?
...
observation = operationQueue.observe(\.operationCount, options: [.new]) { observed, change in
if change.newValue == 0 {
print("operations finished")
}
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.