swift3.0 GCD的使用

作者: yzawyx0220 | 来源:发表于2017-02-07 10:16 被阅读77次

    取消过去的接口

    说起 GCD, 大家肯定回想起类似 dispatch_async 这样的语法,这个语法在swift3中不再适用了,彻底重写了接口
    比如最常用的,在一个异步队列中读取数据, 然后再返回主线程更新 UI, 这种操作在新的 Swift 语法中是这样的:

    DispatchQueue.global().async {
     
        DispatchQueue.main.async {
       
        self.label?.text = "finished"
       
        } 
       
    }
    

    变化很大, 首先 Swift 3 摒弃了 GCD 以前的函数式调用方式。 引入了 DispatchQueue 这个类, 第一行的 DispatchQueue.global().async
    相当于使用全局队列进行异步操作。然后在调用 DispatchQueue.main.async
    使用主线程更新相应的 UI 内容。

    这次对 GCD 的改进还包括优先级的概念。 以往我们使用 Global Queue 的时候,可以使用 DISPATCH_QUEUE_PRIORITY_DEFAULT 或 DISPATCH_QUEUE_PRIORITY_BACKGROUND 等,来指定队列的优先级。 而新的 GCD 引入了 QoS (Quality of Service) 的概念,体现在代码上面就是优先级所对应的名称变了, 对应关系如下:

    * DISPATCH_QUEUE_PRIORITY_HIGH:  .userInitiated
     
    * DISPATCH_QUEUE_PRIORITY_DEFAULT: .default
     
    * DISPATCH_QUEUE_PRIORITY_LOW: .utility
     
    * DISPATCH_QUEUE_PRIORITY_BACKGROUND: .background
    

    如果想以最高优先级执行这个队列, 那么就可以这样:

    DispatchQueue.global(qos: .userInitiated).async {
     
    }
    

    DispatchWorkItem

    除了直接使用 Global Queue, 还可以定义 DispatchWorkItem。 DispatchWorkItem 定义了一个操作的内部代码,以及优先级,特性等等。 它可以直接在任何队列中执行:

    let queue = DispatchQueue(label: "swift.queue")
     
    let workItem = DispatchWorkItem(qos: .userInitiated, flags: .assignCurrentContext) {
     
    }
       
    queue.async(execute: workItem)
    

    dispatch_time_t

    还有一个是对 dispatch_time_t 的改进:

    let delay = DispatchTime.now() + .seconds(60)
    DispatchQueue.main.after(when: delay) {
     // Do something
    }
    

    语法使用起来更加简单。DispatchTime.now() 是当前事前, 然后加上 .seconds(60) 代表 60秒。 再使用 DispatchQueue.main.after 让这个操作在 60 秒后执行。
    以前的语法是这个样子:

    let dispatch_time = dispatch_time(DISPATCH_TIME_NOW, Int64(60 * NSEC_PER_SEC))
    

    这样一比,立竿见影

    相关文章

      网友评论

      • 那夜孤舟:谢了,刚看到swift的gcd,你的总结解决了我不少的疑惑

      本文标题:swift3.0 GCD的使用

      本文链接:https://www.haomeiwen.com/subject/etppittx.html