java定时运行一个url_Swift 4:如何异步使用URLSessionDataTask但请求是否在一个定时队列中?...

使 DispatchQueue 在线程上运行代码 . 您不需要在主线程上执行此操作 . 所以,

// make serial queue

let queue = DispatchQueue(label: "getData")

// for delay

func wait(seconds: Double, completion: @escaping () -> Void) {

queue.asyncAfter(deadline: .now() + seconds) { completion() }

}

// usage

for url in urls {

wait(seconds: 2.0) {

self.get(url: url) { (itemCount) in

// update UI related to itemCount

}

}

}

顺便说一下,你的 get(url: url) 功能并不是那么好 .

func get(url: URL, completionHandler: @escaping ([Int]) -> Void) {

let session = URLSession.shared

let task = session.dataTask(with: url, completionHandler: { (data, response, error) in

if let error = error {

print(error.localizedDescription)

/* Don't need to use main thread

DispatchQueue.main.async {

print(error.localizedDescription)

}

*/

return

}

let data = data!

guard let response = response as? HTTPURLResponse, response.statusCode == 200 else {

print("Server Error")

/* Don't need to use main thread

DispatchQueue.main.async {

print("Server Error")

}

*/

return

}

if response.mimeType == "application/json" {

do {

let json = try JSONSerialization.jsonObject(with: data) as! [String: Any]

if json["success"] as! Bool == true {

if let count = json["total_count"] as? Int {

self.itemsCount.append(count)

// append all data that you need and pass it to completion closure

DispatchQueue.main.async {

completionHandler(self.itemsCount)

}

}

}

} catch {

print(error.localizedDescription)

}

}

})

task.resume()

}

我建议你学习 GCD (用于线程)和 escaping closure (用于完成处理程序)的概念 .

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值