iOS Concurrency with GCD and Operations
Learn how to add concurrency to your apps! Keep your app’s UI responsive to give your users a great user experience, and learn how to avoid common concurrency problems, like race condition, priority inversion and deadlock. By Audrey Tam.
Who is this for?
Experienced iOS developers, with an intermediate level of knowledge of Swift and iOS development.
Learn how to use dispatch queues and operations in your apps, to keep your app’s UI responsive, and to avoid data races, priority inversion and deadlock. You’ll learn how to manage groups of tasks with dependencies and how to use asynchronous API methods in dispatch groups and operation queues.
Covered concepts
- Global Dispatch Queues
- Serial vs. Concurrent Queues
- Synchronous vs. Asynchronous Dispatch
- Dispatch Work Item, Dispatch Group, Dispatch Semaphore
- Data Races, TSan and Threadsafe Classes
- Quality of Service and Priority Inversion
- Avoiding Deadlock
- Operation and OperationQueue
- Asynchronous Operation
- Operation Dependencies
- Canceling Operations
- Concurrency and Core Data
- Reactive Frameworks
Part 1: Getting Started
Find out what's in store for you as you work through this course and why it's important.
Learn about the different Grand Central Dispatch global queues and how they manage threads for you.
Develop your understanding of serial vs. concurrent queues and synchronous vs. asynchronous dispatch.
Learn how to create and execute a dispatch work item if you want to be notified when the task completes, or if you might need to cancel the task.
Practice using dispatch queues to download and display images, through a hands-on challenge.
Learn how to use the asynchronous URLSession API to download images in the background, then dispatch back to the main queue to display them.
Learn how to create your own asynchronous version of any function, where you can specify the run and completion queues.
Practice creating an asynchronous version of a function in a real app, through a hands-on challenge.
Learn about two reactive programming frameworks, which unify and coordinate the numerous asynchronous programming tools.
Let's review what you've learned about concurrency and dispatch queues and discuss what's next.
Part 2: Grand Central Dispatch
Find out what you'll learn about concurrency in this part of the course, and why it's important.
Learn how to create a group of slow tasks, run them on a dispatch queue and be notified when they all finish.
Learn how to wrap an asynchronous function so you can run it in a dispatch group, and it tells the group when it really finishes.
In a hands-on challenge, practice wrapping the asynchronous function URLSession dataTask to download a group of images.
Learn how to use a dispatch semaphore to control the number of dispatch group tasks that run at the same time.
Learn how to prevent the three potential concurrency problems: priority inversion, data races and deadlocks.
Explore the priority inversion problem by creating a situation where a high-priority task must wait for lower-priority tasks.
Learn how to use Xcode's TSan tool to detect data races, then use a dispatch barrier to make a class threadsafe.
Practice using TSan and making a class threadsafe with a dispatch barrier, through a hands-on challenge.
Halfway through this course, let's review what you've learned about concurrency problems and dispatch groups and discuss what's next.
Part 3: Operations I
Let's review what you'll be learning about Operations and OperationQueues in this part of the course, and why it's important.
Get started with Operations by learning how to create and use BlockOperations and what they're useful for.
Learn how to define a reusable operation, with input and output properties, as a subclass of Operation.
Discover the real power of Operations happens when you add them to an OperationQueue and let it handle scheduling and execution.
Explore how Operations run on an OperationQueue by executing the same set of tasks you used with BlockOperation.
In a hands-on challenge, practice using an OperationQueue to apply a tilt-shift filter to an array of images.
Find out what you need to do to run an asynchronous operation in an OperationQueue, so the OperationQueue knows when it really finishes.
Create an AsyncOperation subclass of Operation to handle Operation state changes, then subclass AsyncOperation to wrap an asynchronous function.
In a hands-on challenge, practice subclassing AsyncOperation to wrap the image download task, then create instances to download an array of images.
Let's review what you've learned in this part about Operations, OperationQueues and AsyncOperations, and discuss what's next.
Part 4: Operations II
Find out what you'll be learning in this part of the course about canceling or defining dependencies on Operations and about Core Data and SwiftUI with Combine.
Learn how to set up a dependency between two operations so an OperationQueue can run them in the correct order.
In a hands-on challenge, practice defining an Operation dependency to apply the tilt-shift filter after an image finishes downloading.
Learn how to cancel download and filter operations in the sample app, if an image's cell scrolls off the screen.
Learn the wrong way and the right way to share a Core Data NSManagedObject between threads in an app.
Take a walk through a SwiftUI+Combine version of the Concurrency app, using Publishers to download and tilt-shift filter images.
Let's review everything you've learned in this course about Grand Central Dispatch, concurrency problems, Operations and OperationQueues.