2017-10-04-GCD-在-Swift-中的用法

DispatchQueue

Swift 中,对 GCD 语法进行了彻底改写。引入了 DispatchQueue 这个类。

先来看看在一个异步队列中读取数据, 然后再返回主线程更新 UI, 这种操作在新的 Swift 语法中是这样的:

DispatchQueue.global().async {

    DispatchQueue.main.async {

		// 更新UI操作

    }

}

DispatchQueue.global().async 相当于使用全局队列进行异步操作。然后在调用 DispatchQueue.main.async 使用主线程更新相应的 UI 内容。

优先级

新的 GCD 引入了 QoS (Quality of Service) 的概念。

先看看下面的代码:

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

}

QoS 对应的就是 Global Queue 中的优先级。 其优先级由最低的 background 到最高的 userInteractive 共五个,还有一个未定义的 unspecified

public static let background: DispatchQoS

public static let utility: DispatchQoS

public static let `default`: DispatchQoS

public static let userInitiated: DispatchQoS

public static let userInteractive: DispatchQoS

public static let unspecified: DispatchQoS

自定义 Queue

除了直接使用 DispatchQueue.global().async 这种封装好的代码外,还可以通过DispatchWorkItem 自定义队列的优先级,特性:

let queue = DispatchQueue(label: "swift_queue")
let dispatchworkItem = DispatchWorkItem(qos: .userInitiated, flags: .inheritQoS) {
    
}
queue.async(execute: dispatchworkItem)

GCD定时器

Swift 中 dispatch_time的用法改成了:

let delay = DispatchTime.now() + .seconds(60)
DispatchQueue.main.asyncAfter(deadline: delay) { 
    
}

相较与OC来说更易读了:

let dispatch_time = dispatch_time(DISPATCH_TIME_NOW, Int64(60 * NSEC_PER_SEC))
最近的文章

2017-12-26-浅谈-Tagged-Pointer

正文下面代码会发生什么问题?@property (nonatomic, strong) NSString *target;//....dispatch_queue_t queue = dispatch_queue_create("parallel", DISPATCH_QUEUE_CONCURRENT);for (int i = 0; i < 1000000 ; i++) { dispatch_async(queue, ^{ self.target = [NSSt...…

loxue继续阅读
更早的文章

2017-09-11-Swift-4-新特性

private 权限扩大在 Swift 4 中,extension 可以读取 private 变量了。Swift 3 中,如果将主体函数的变量定义为 private,则其 extension 无法读取此变量,必须将其改为 filePrivate 才可以。单向区间单向区间是一个新的类型,主要分两种:确定上限和确定下限的区间。直接用字面量定义大概可以写成 …6和 2…例如let intArr = [0, 1, 2, 3, 4]let arr1 = intArr[...3] // [0, 1,...…

loxue继续阅读