这个方法主要和下面几个方法一起使用的:
- dispatch_group_enter
- dispatch_group_leave
- dispatch_group_notify
- dispatch_group_wait
dispatch_group_enter
和 dispatch_group_leave
一般是成对出现的, 进入一次,就得离开一次。也就是说,当离开和进入的次数相同时,就代表任务组完成了。如果enter
比leave
多,那就是没完成,如果leave
调用的次数多了, 会崩溃的;
看如下代码:
- (void)viewDidLoad {
[super viewDidLoad];
dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
dispatch_async(queue, ^{
[self test];
});
}
- (void)test
{
dispatch_group_t group = dispatch_group_create();
dispatch_group_enter(group);
dispatch_group_enter(group);
NSLog(@"加入");
NSLog(@"加入");
dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
// 异步2秒后离开
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2 * NSEC_PER_SEC)), queue, ^{
NSLog(@"即将离开 - 1");
dispatch_group_leave(group);
NSLog(@"已经离开 - 1");
});
// 异步3秒后离开
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)), queue, ^{
NSLog(@"即将离开 - 2");
dispatch_group_leave(group);
NSLog(@"已经离开 - 2");
});
dispatch_group_notify(group, queue, ^{
NSLog(@"都完成了");
});
NSLog(@"开始等待");
dispatch_group_wait(group, dispatch_time(DISPATCH_TIME_NOW, (int64_t)(6 * NSEC_PER_SEC)));
NSLog(@"等待结束");
}
打印的结果是:
2018-03-19 11:55:59.077862+0800 Test[26326:1160676] 加入
2018-03-19 11:55:59.078010+0800 Test[26326:1160676] 加入
2018-03-19 11:55:59.078649+0800 Test[26326:1160676] 开始等待
2018-03-19 11:56:01.187318+0800 Test[26326:1160674] 即将离开 - 1
2018-03-19 11:56:01.187573+0800 Test[26326:1160674] 已经离开 - 1
2018-03-19 11:56:02.377367+0800 Test[26326:1160674] 即将离开 - 2
2018-03-19 11:56:02.377703+0800 Test[26326:1160674] 已经离开 - 2
2018-03-19 11:56:02.377732+0800 Test[26326:1160676] 等待结束
2018-03-19 11:56:02.377755+0800 Test[26326:1160681] 都完成了
dispatch_group_wait
:在任务组完成时调用,或者任务组超时是调用(完成指的是enter
和leave
次数一样多)
dispatch_group_notify
:不管超不超时,只要任务组完成,会调用,不完成不会调用
上面代码,enter
了两次,wait
是会阻塞当前线程的,wait
时间为6秒, 在6秒内leave
了两次, 当最后一次leave
的时候,wait
就会执行(打开阻塞), 继续往下执行;NSLog(@"已经离开 - 2");
和NSLog(@"等待结束");
是异步进行的;谁先谁后不一定;
最后一次的dispatch_group_leave(group);
执行完之后,dispatch_group_wait(group, dispatch_time(DISPATCH_TIME_NOW, (int64_t)(6 * NSEC_PER_SEC)));
这条代码的阻塞就立即打开了,然后往下执行
网友评论