Standard library header  (C++11) (original) (raw)

This header is part of the thread support library.

[edit] Synopsis

namespace std { class condition_variable; class condition_variable_any;   void notify_all_at_thread_exit(condition_variable& cond, unique_lock lk);   enum class cv_status { no_timeout, timeout }; }

[edit] Class std::condition_variable

namespace std { class condition_variable { public: condition_variable(); ~condition_variable();   condition_variable(const condition_variable&) = delete; condition_variable& operator=(const condition_variable&) = delete;   void notify_one() noexcept; void notify_all() noexcept; void wait(unique_lock& lock); template void wait(unique_lock& lock, Pred pred); template<class Clock, class Duration> cv_status wait_until(unique_lock& lock, const chrono::time_point<Clock, Duration>& abs_time); template<class Clock, class Duration, class Pred> bool wait_until(unique_lock& lock, const chrono::time_point<Clock, Duration>& abs_time, Pred pred); template<class Rep, class Period> cv_status wait_for(unique_lock& lock, const chrono::duration<Rep, Period>& rel_time); template<class Rep, class Period, class Pred> bool wait_for(unique_lock& lock, const chrono::duration<Rep, Period>& rel_time, Pred pred);   using native_handle_type = /* implementation-defined */; native_handle_type native_handle(); }; }

[edit] Class std::condition_variable_any

namespace std { class condition_variable_any { public: condition_variable_any(); ~condition_variable_any();   condition_variable_any(const condition_variable_any&) = delete; condition_variable_any& operator=(const condition_variable_any&) = delete;   void notify_one() noexcept; void notify_all() noexcept;   // noninterruptible waits template void wait(Lock& lock); template<class Lock, class Pred> void wait(Lock& lock, Pred pred);   template<class Lock, class Clock, class Duration> cv_status wait_until(Lock& lock, const chrono::time_point<Clock, Duration>& abs_time); template<class Lock, class Clock, class Duration, class Pred> bool wait_until(Lock& lock, const chrono::time_point<Clock, Duration>& abs_time, Pred pred); template<class Lock, class Rep, class Period> cv_status wait_for(Lock& lock, const chrono::duration<Rep, Period>& rel_time); template<class Lock, class Rep, class Period, class Pred> bool wait_for(Lock& lock, const chrono::duration<Rep, Period>& rel_time, Pred pred);   // interruptible waits template<class Lock, class Pred> bool wait(Lock& lock, stop_token stoken, Pred pred); template<class Lock, class Clock, class Duration, class Pred> bool wait_until(Lock& lock, stop_token stoken, const chrono::time_point<Clock, Duration>& abs_time, Pred pred); template<class Lock, class Rep, class Period, class Pred> bool wait_for(Lock& lock, stop_token stoken, const chrono::duration<Rep, Period>& rel_time, Pred pred); }; }