栅栏函数的作用与barrier的意思相同,在进程管理中起到一个栅栏的作用,它等待所有位于barrier函数之前的操作执行完毕后执行,并且在barrier函数执行之后,barrier函数之后的操作才会得到执行。
下面看运行结果来解析他们之间的不同之处。
dispatch_queue_t queue = dispatch_queue_create("并行队列", DISPATCH_QUEUE_CONCURRENT); NSLog(@"主线程开始"); dispatch_async(queue, ^{ NSLog(@"----1-----"); }); dispatch_barrier_sync(queue, ^{ NSLog(@"----barrier-----"); }); NSLog(@"主线程中间"); dispatch_async(queue, ^{ NSLog(@"----2-----"); }); NSLog(@"主线程结束");
下面是运行结果
Barrier[26875:324702] 主线程开始 2019-02-14 14:01:06.841538+0800 Barrier[26875:324747] ----1----- 2019-02-14 14:01:06.841639+0800 Barrier[26875:324702] ----barrier----- 2019-02-14 14:01:06.841731+0800 Barrier[26875:324702] 主线程中间 2019-02-14 14:01:06.841826+0800 Barrier[26875:324702] 主线程结束 2019-02-14 14:01:06.841831+0800 Barrier[26875:324747] ----2-----
下面我只改一个函数就是改成异步
dispatch_queue_t queue = dispatch_queue_create("并行队列", DISPATCH_QUEUE_CONCURRENT); NSLog(@"主线程开始"); dispatch_async(queue, ^{ NSLog(@"----1-----"); }); dispatch_barrier_async(queue, ^{ NSLog(@"----barrier-----"); }); NSLog(@"主线程中间"); dispatch_async(queue, ^{ NSLog(@"----2-----"); }); NSLog(@"主线程结束");
下面是打印结果
Barrier[27065:327361] 主线程开始 2019-02-14 14:03:12.051717+0800 Barrier[27065:327485] ----1----- 2019-02-14 14:03:12.051804+0800 Barrier[27065:327361] 主线程中间 2019-02-14 14:03:12.051826+0800 Barrier[27065:327485] ----barrier----- 2019-02-14 14:03:12.051924+0800 Barrier[27065:327487] ----2----- 2019-02-14 14:03:12.051904+0800 Barrier[27065:327361] 主线程结束
dispatch_barrier_sync 相当于是会阻塞当前线程,我们这里当前线程是主线程,必须等待dispatch_barrier_sync之前的代码执行完成之后,后面的才会执行。
dispatch_barrier_async 不会阻塞当前线程。dispatch_barrier_async 会等待前面执行的完成之后才执行dispatch_barrier_async里面的。但是并不会阻塞其他线程执行。这里我们是主线程。这里 主线程中间打印是在----barrier----- 之前。所以没有阻塞当前线程。
这二函数的使用还需要注意:
在使用栅栏函数时.使用自定义队列才有意义,如果用的是串行队列或者系统提供的全局并发队列,这个栅栏函数的作用等同于一个同步函数的作用
网友评论