GCD中的dispatch_barrier_*函数的使用(栅栏函数)
注意:在使用栅栏函数时.使用自定义队列才有意义,如果用的是串行队列或者系统提供的全局并发队列,这个栅栏函数的作用等同于一个同步函数的作用
1:dispatch_barrier_async将自己的任务插入到队列之后,不会等待自己的任务结束,它会继续把后面的任务插入到队列,然后等待自己的任务结束后才执行后面任务。
- (void)asyncbarrier{
dispatch_queue_t queue = dispatch_queue_create("12312312", DISPATCH_QUEUE_CONCURRENT);
NSLog(@"%@",@"ddd");
dispatch_async(queue, ^{
NSLog(@"----1-----%@", [NSThread currentThread]);
});
dispatch_async(queue, ^{
NSLog(@"----2-----%@", [NSThread currentThread]);
});
dispatch_barrier_async(queue, ^{
for(int i=0;i<10000);i++){
NSLog(@"----barrier-----%@", [NSThread currentThread]);
}
});
NSLog(@"%@",@"aaa");
dispatch_async(queue, ^{
NSLog(@"----3-----%@", [NSThread currentThread]);
});
NSLog(@"%@",@"bbb");
dispatch_async(queue, ^{
NSLog(@"----4-----%@", [NSThread currentThread]);
});
NSLog(@"%@",@"ccc");
}
输出结果:ddd—>1/2—>1/2 --> aaa—>bbb—>ccc—->barrier——>3/4——>3/4
2,dispatch_barrier_sync将自己的任务插入到队列的时候,需要等待自己的任务结束之后才会继续插入被写在它后面的任务,然后执行它们
- (void)syncbarrier{
dispatch_queue_t queue = dispatch_queue_create("12312312", DISPATCH_QUEUE_CONCURRENT);
NSLog(@"%@",@"ddd");
dispatch_async(queue, ^{
NSLog(@"----1-----%@", [NSThread currentThread]);
});
dispatch_async(queue, ^{
NSLog(@"----2-----%@", [NSThread currentThread]);
});
dispatch_barrier_sync(queue, ^{
for(int i=0;i<10000);i++){
NSLog(@"----barrier-----%@", [NSThread currentThread]);
}
});
NSLog(@"%@",@"aaa");
dispatch_async(queue, ^{
NSLog(@"----3-----%@", [NSThread currentThread]);
});
NSLog(@"%@",@"bbb");
dispatch_async(queue, ^{
NSLog(@"----4-----%@", [NSThread currentThread]);
});
NSLog(@"%@",@"ccc");
}
输出结果:ddd—>1/2—>1/2—-—->barrier ——> aaa—>bbb—>ccc——>3/4——>3/4