Slide 27
Slide 27 text
Grand
Central
Dispatch
API
Queues
Tasks
Dispatch group
Regroups tasks in a set to synchronize. It is based on a
counter of outstanding tasks
dispatch_group_t group = dispatch_group_create();
dispatch_block_t task1 = ^{ printf("Task 1\n");},
task2 = ^{ printf("Task 2\n");},
task3 = ^{
NSInteger i;
for(i = 0; i < INT16_MAX; ++i);
};
dispatch_queue_t queue;
queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0);
dispatch_group_async(group,queue,task1);
dispatch_group_async(group,queue,task2);
dispatch_group_async(group,queue,task3);
/* Wait for the oustanding tasks counter to be null*/
dispatch_group_wait(group, DISPATCH_TIME_FOREVER);
27 / 36