Thread Synchronization with Condition Variables or Tasks

In case you are using promise and future to synchronize threads, they have a lot in common with condition variables. But most of the time, task are the better choice.

Synchronization of threads

To get the big picture, get the facts. The table compares condition variables with tasks (promise and future).

The benefit of a condition variable to a promise and future is, that you can use condition variables to synchronize threads multiple times. In opposite to that, a promise can send its notification only once. So you have to use more promise and future pairs to get the functionality of a condition variable. But in case you use the condition variable only for one synchronization, the condition variable is a lot more difficult to use in right way. So a promise and future pair needs no shared variable and therefore no lock, they are not prone to spurious wakeups or lost wakeups. In addition to that, they can handle exceptions. So there are lot of reasons to prefer tasks to condition variables.

With the help of the promise sendReady (line32) I get the future fut (line34). The promise signalises in this case by his return value void (std::promise<void> sendReady), that it is only capable of sending notifications. Both communications endpoints are moved into the thread t1 respectively t2 (line 35 and 36). The future is waiting with its call fut.wait() (line 15) for the notification of the promise: prom.set_value() (line 24).

As well the structure as the output of the program matches the program in den post about the condition variable.

What's next?

So that was the overview of the mulitithreading interface. Now it's time to have a deeper look into mulithreading in C++. Although the most programmers will and should never use the features of C++ memory model, it gives you a deeper insight into the challenges of mulitthrading programming. The next post starts with an overview of the C++ memory model. (Proofreader Alexey Elymanov)

Go to Leanpub/cpplibrary"What every professional C++ programmer should know about the C++ standard library".Get your e-book. Support my blog.