在URLSession.shared.dataTask的完成处理程序内部的闭包

时间:2017-04-19 20:12:08

标签: ios swift asynchronous nsurlsession

我在URLSession.shared.dataTask任务中调用了一个闭包。 问题是,当我在闭包内设置断点时,它将无法完成执行。

func query(url: String, args: [String:String], completion: @escaping (_ data: Data) -> Void) {
// Create request url in order to query API.
let url = makeGetRequestUsing(url: url, args: args)
let task = URLSession.shared.dataTask(with: url!) { data, response, error in
    guard let data = data, error == nil else {
        print("error:", error ?? "")
        return
    }
    completion(data)
}

task.resume()

这就是我所说的。

self.comments = []
api.query(url: url, args: args) { data in
    let jsonData = try! JSONSerialization.jsonObject(with: data)
    print(String(data: data, encoding: .utf8))
    if let jsonArray = jsonData as? [[String: Any]] {
        // Create comments from the json received.
        for i in 0..<jsonArray.count {
            do {
                self.comments.append(try Comment(json: jsonArray[i]))
            } catch {
                print(error)
            }
        }
        DispatchQueue.main.async {
            self.refreshComments()
        }
    }
}

我在完成处理程序中设置了一个断点,似乎错误来自于Comment类的初始化。

init(json: [String: Any]) throws {
// Get the comment text.
guard let comment = json[Comment.commentText] as? String else {
  throw SerializationError.missing(Comment.commentText)
}

// Get userImage.
guard let userId = json[Comment.userId] as? Int,
  let userImage = APIData.shared.getImage(url: "/userImageForId", args: ["id": String(userId)]) else {
    throw SerializationError.missing(Comment.userId)
}

// Get userename.
guard let resp = APIData.shared.getQuery(url: "/userNameForId", args: ["id": String(userId)]) as? [String: String],
  let username = resp[Comment.username] else {
    throw SerializationError.missing(Comment.username)
}

self.comment = comment
self.username = username
self.userImage = userImage

}

getImage和getQuery与第一个代码相同。我发起一个任务,等到我使用信号量得到结果。

1 个答案:

答案 0 :(得分:0)

你说你的闭包不会完成执行,你还提到你在代码中的某个地方使用了一个尚未发布的信号量。您很可能错误地使用了信号量而且阻塞了您的线程。

我可以看到问题中没有任何内容可以保证首先使用信号量。通过引入信号量和异常,您似乎使代码变得比必要的更复杂。

我建议你阅读一下如何对代码进行单元测试并逐步构建逻辑。看起来你咬的时间比你现在咀嚼的还要多。