std::condition_variable_any
Defined in header
<condition_variable>
|
||
class condition_variable_any;
|
(since C++11) | |
The condition_variable_any
class is a generalization of std::condition_variable. Whereas std::condition_variable works only on std::unique_lock<std::mutex>, condition_variable_any
can operate on any user-defined lock that meets the BasicLockable
requirements.
condition_variable_any
provides similar functionality to std::condition_variable. It is a synchronization primitive that can be used to block some number of threads until:
- a notification is received from another thread
- a timeout expires, or
- a spurious wakeup occurs
Any thread that intends to wait on std::condition_variable_any
has to acquire a lock first. The wait operations atomically release the lock and suspend the execution of the thread. When the condition variable is notified, the thread is awakened, and the lock is reacquired.
The class std::condition_variable_any
is a standard-layout class. It is not copy-constructible, move-constructible, copy-assignable, or move-assignable.
If the lock is std::unique_lock, std::condition_variable may provide better performance.
Contents |
[edit] Member functions
constructs the object (public member function) |
|
destructs the object (public member function) |
|
operator=
[deleted]
|
not copy-assignable (public member function) |
Notification |
|
notifies one waiting thread (public member function) |
|
notifies all waiting threads (public member function) |
|
Waiting |
|
blocks the current thread until the condition variable is woken up (public member function) |
|
blocks the current thread until the condition variable is woken up or after the specified timeout duration (public member function) |
|
blocks the current thread until the condition variable is woken up or until specified time point has been reached (public member function) |
[edit] Notes
A possible use for std::condition_variable_any
with custom Lockable
types is to provide convenient interruptible waits: the custom lock operation would both lock the associated mutex as expected, and also perform the necessary setup to notify this condition variable when the interrupting signal is received.[1]
[edit] References
- ↑ A. Williams (2012), "C++ concurrency in action" 9.2.4 Interupting a wait on std::condition_variable_any