俗称栅栏函数的
barrier
对于async
和sync
,你了解他的具体含义吗?sync
会阻塞线程吗,async
的作用又是什么?如果你也存在疑惑,请继续看我为你详情举例解答。
1、dispatch_barrier_async , 会将添加到queue前面的任务执行完之后,才会执行后面的任务,并不会阻塞当前的线程
2、dispatch_barrier_sync , 会将添加到queue前面的任务执行完之后,才会执行后面的任务,并且会阻塞当前的线程
具体请看下述示例代码:
dispatch_barrier_async
- (void)viewDidLoad {
[super viewDidLoad];
_queue = dispatch_queue_create("com.htmi.Zc", DISPATCH_QUEUE_CONCURRENT);
_dic = [NSMutableDictionary dictionary];
[self barrier];
}
- (void)barrier{
NSLog(@"start");
dispatch_async(_queue, ^{
NSLog(@"1");
});
dispatch_async(_queue, ^{
NSLog(@"2");
});
dispatch_barrier_async(_queue, ^{
NSLog(@"3");
});
NSLog(@"6");
dispatch_async(_queue, ^{
NSLog(@"4");
});
dispatch_async(_queue, ^{
NSLog(@"5");
});
NSLog(@"end");
}
执行顺序:
start 6 1 2 end 3 4 5
- 比如加上延时函数再看下效果
- (void)barrier{
NSLog(@"start");
dispatch_async(_queue, ^{
sleep(3);
NSLog(@"1");
});
dispatch_async(_queue, ^{
NSLog(@"2");
});
dispatch_sync(_queue, ^{
sleep(1);
NSLog(@"7");
});
dispatch_barrier_async(_queue, ^{
NSLog(@"3");
});
NSLog(@"6");
dispatch_async(_queue, ^{
NSLog(@"4");
});
dispatch_async(_queue, ^{
NSLog(@"5");
});
NSLog(@"end");
}
执行顺序:
start 2 6 7 end 1 3 4 5
说明 dispatch_barrier_async , 会将添加到queue前面的任务执行完之后,才会执行后面的任务,并不会阻塞当前的线程,45一定在3后
假如改为 dispatch_barrier_async
- (void)barrier{
NSLog(@"start");
dispatch_async(_queue, ^{
sleep(3);
NSLog(@"1");
});
dispatch_async(_queue, ^{
NSLog(@"2");
});
dispatch_sync(_queue, ^{
sleep(1);
NSLog(@"7");
});
dispatch_barrier_sync(_queue, ^{
NSLog(@"3");
});
NSLog(@"6");
dispatch_async(_queue, ^{
NSLog(@"4");
});
dispatch_async(_queue, ^{
NSLog(@"5");
});
NSLog(@"end");
}
执行顺序:start 2 7 1 3 6 end 4 5
后被添加到栅栏函数的queue中的任务,一需要等待栅栏函数前面的任务执行完毕之后,才可以执行,也就是说127一定在3前面,45一定在3后,而不一样的是6和end的打印,当换成sync之后会阻塞当前线程会等待前面都执行完毕之后,才会打印这两个,而之前的async,是不会阻塞的,会打印这两个值,而其余的任务有顺序,而换成sync之后,在当前线程执行的任务也有了顺序,这就是dispatch_barrier_sync 和 dispatch_barrier_async 的区别
网友评论