版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011374318/article/details/87926573
GCD 中的组
在 GCD 中,使用 dispatch_group_t
可以很方便的将任务分组,如果存在一个任务需要在一系列任务完成后才可以执行,那么使用组的相关方法则十分方便。
使用 dispatch_group_t dispatch_group_create(void);
函数创建一个 dispatch_group_t
类型的变量,即组。
然后使用下面的方法为创建的组关联任务,指定的任务将在指定的队列中异步执行。
void dispatch_group_async(dispatch_group_t group,
dispatch_queue_t queue,
dispatch_block_t block);
当然,也可以添加执行函数。
void dispatch_group_async_f(dispatch_group_t group,
dispatch_queue_t queue,
void *_Nullable context,
dispatch_function_t work);
如果,不使用这两个函数,还可以下面的方法表示任务与组的关联以及取消关联。
void dispatch_group_enter(dispatch_group_t group);
void dispatch_group_leave(dispatch_group_t group);
应当注意,这两个方法是成对使用的。
当添加相关任务到指定组后,需要指定组中任务结束后,需要执行的任务或函数。
void dispatch_group_notify(dispatch_group_t group,
dispatch_queue_t queue,
dispatch_block_t block);
void dispatch_group_notify_f(dispatch_group_t group,
dispatch_queue_t queue,
void *_Nullable context,
dispatch_function_t work
当组中任务执行完毕后,需要执行的任务便会提交到指定的队列中,这是异步执行的。
使用 long dispatch_group_wait(dispatch_group_t group, dispatch_time_t timeout);
函数,可以等待指定组中的任务执行完毕,或者超时后,再继续执行当前任务。
其实现原理可以参考 Neroxie 的博文