GCD 中的组

版权声明:本文为博主原创文章,未经博主允许不得转载。 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 的博文

猜你喜欢

转载自blog.csdn.net/u011374318/article/details/87926573
gcd