Promise and Future: Returning a Notification

This lesson teaches us how to return a notification while using std::promise and future in C++.

If we use promises and futures to synchronize threads, they have a lot in common with condition variables. Most of the time, promises and futures are the better choices. Before we present an example, here is the big picture.

Criteria Condition Variables Tasks
Multiple synchronizations Yes No
Critical section Yes No
Error handling in receiver No Yes
Spurious wakeup Yes No
Lost wakeup Yes No

The advantage of using a condition variable over a promise and future is that we can use condition variables to synchronize threads multiple times. In contrast to that, a promise can send its notification only once, so we have to use more promise and future pairs to get the functionality of a condition variable. If we use the condition variable for only one synchronization, the condition variable is a lot more difficult to use in the right way. A promise and future pair needs no shared variable and, therefore, it doesn’t have a lock, and isn’t prone to spurious or lost wakeups. In addition to that, tasks can handle exceptions. There are lots of reasons to prefer tasks to condition variables.

Remember how difficult it was to use condition variables? If not, here are the key parts required to synchronize two threads.

Get hands-on with 1300+ tech skills courses.