Grand Central Dispatch Part 2
data:image/s3,"s3://crabby-images/6a04b/6a04b3ac4e210e735b10006236f98f7a2b8b9991" alt=""
Part 2 : DispatchGroup, DispatchSemaphore
So we've seen how to use GCD with one task, but how to deal with multiple tasks ? This is where DispatchGroup is useful.
DispatchGroup
We start by initializing a DispatchGroup, then provide it as an argument to the async method of our dispatch queue.
For example :
data:image/s3,"s3://crabby-images/cff49/cff496d068b1aa085518bc76dfb8019e68fa78d1" alt="let dispatchGroup = DispatchGroup() someQueue.async(group: group) { /* some work */ } someQueue.async(group: group) { /* some other work */ } someOtherQueue.async(group: group) { /* another work */ }"
We can see that dispatchGroup is not attached to a single dispatch. That mean we can submit multiple tasks to multiples queues.
When all tasks are done, DispatchGroup will notify us.
data:image/s3,"s3://crabby-images/d2ad9/d2ad95c45f664bd2890e50d2ed9ced0055665c3f" alt=""
Note that notify take a dispatch queue as a parameter, that mean the closure will be executed in the specified one.
Let's see a more concrete example, for each task, we enter the group, and leave it for each completed task.
data:image/s3,"s3://crabby-images/106c7/106c7299b95892a5e8281f146413cbbff75392a4" alt=""
See how we use the enter and leave, if we forgot to leave after entering, the app will hang forever !
DispatchSemaphore
Ok, we can work with multiple tasks, but imagine that we need to prevent tasks to access the same shared resource, like a read/write a file ? Or limit how many downloads can happen at once ? Using DispatchSemaphore can help us with that.
For example :
data:image/s3,"s3://crabby-images/0b765/0b765cfae2abc93ba102ff3eaee27821188e46eb" alt=""
Here, the app will loop in our `for` statement 7 times, and during the loop, will wait 2 seconds before running again.