提交一个障碍任务,这个任务之前的任务安规则正常执行,等到它之前的任务全部执行完毕之后,才开始执行这个障碍任务。
但是这个障碍任务本身不管是否在并行队列里面,这个障碍任务本身是单独执行的。
障碍任务执行完成后,再按正常规则执行后续的任务
示例:
- (IBAction)GCD_dispatch_barrier_async_buttonAction:(UIButton *)sender {
//创建一个并行执行队列
dispatch_queue_t queue = dispatch_queue_create("queueIdentifier", DISPATCH_QUEUE_CONCURRENT);
//以下两个任务执行顺序不定,因为它们是并行任务
dispatch_async(queue, ^{
NSLog(@"&thread:%@-------",[NSThread currentThread]);
});
dispatch_async(queue, ^{
NSLog(@"&thread:%@-------",[NSThread currentThread]);
});
//将队列中已添加的任务执行完成后,单独执行下面的任务,不会并行执行
dispatch_barrier_async(queue, ^{
NSLog(@"&thread:%@-------",[NSThread currentThread]);
});
//上面的任务执行完成后继续正常并行执行任务
dispatch_async(queue, ^{
NSLog(@"&thread:%@-------",[NSThread currentThread]);
});
dispatch_async(queue, ^{
NSLog(@"&thread:%@-------",[NSThread currentThread]);
});
}
输出如下:
@thread:{number = 3, name = (null)}——–
#thread:{number = 3, name = (null)}——-
$barrier:thread:{number = 3, name = (null)}——-
^thread:{number = 3, name = (null)}——-
&thread:{number = 3, name = (null)}——-