This header is part of thethread support library.
Classes | ||
(C++17) | provides shared mutual exclusion facility (class)[edit] | |
(C++14) | provides shared mutual exclusion facility and implements locking with a timeout (class)[edit] | |
(C++14) | implements movable shared mutex ownership wrapper (class template)[edit] | |
Functions | ||
(C++14) | specializes thestd::swap algorithm (function template)[edit] |
namespace std{class shared_mutex;class shared_timed_mutex;template<class Mutex>class shared_lock;template<class Mutex>void swap(shared_lock<Mutex>& x, shared_lock<Mutex>& y)noexcept;}
namespace std{class shared_mutex{public: shared_mutex(); ~shared_mutex(); shared_mutex(const shared_mutex&)= delete; shared_mutex& operator=(const shared_mutex&)= delete; // exclusive ownershipvoid lock();// blockingbool try_lock();void unlock(); // shared ownershipvoid lock_shared();// blockingbool try_lock_shared();void unlock_shared(); using native_handle_type=/* implementation-defined */; native_handle_type native_handle();};}
namespace std{class shared_timed_mutex{public: shared_timed_mutex(); ~shared_timed_mutex(); shared_timed_mutex(const shared_timed_mutex&)= delete; shared_timed_mutex& operator=(const shared_timed_mutex&)= delete; // exclusive ownershipvoid lock();// blockingbool try_lock();template<class Rep,class Period>bool try_lock_for(const chrono::duration<Rep, Period>& rel_time);template<class Clock,class Duration>bool try_lock_until(const chrono::time_point<Clock, Duration>& abs_time);void unlock(); // shared ownershipvoid lock_shared();// blockingbool try_lock_shared();template<class Rep,class Period>bool try_lock_shared_for(const chrono::duration<Rep, Period>& rel_time);template<class Clock,class Duration>bool try_lock_shared_until(const chrono::time_point<Clock, Duration>& abs_time);void unlock_shared();};}
namespace std{template<class Mutex>class shared_lock{public:using mutex_type= Mutex; // construct/copy/destroy shared_lock()noexcept;explicit shared_lock(mutex_type& m);// blocking shared_lock(mutex_type& m, defer_lock_t)noexcept; shared_lock(mutex_type& m, try_to_lock_t); shared_lock(mutex_type& m, adopt_lock_t);template<class Clock,class Duration> shared_lock(mutex_type& m,const chrono::time_point<Clock, Duration>& abs_time);template<class Rep,class Period> shared_lock(mutex_type& m,const chrono::duration<Rep, Period>& rel_time); ~shared_lock(); shared_lock(const shared_lock&)= delete; shared_lock& operator=(const shared_lock&)= delete; shared_lock(shared_lock&& u)noexcept; shared_lock& operator=(shared_lock&& u)noexcept; // lockingvoid lock();// blockingbool try_lock();template<class Rep,class Period>bool try_lock_for(const chrono::duration<Rep, Period>& rel_time);template<class Clock,class Duration>bool try_lock_until(const chrono::time_point<Clock, Duration>& abs_time);void unlock(); // modifiersvoid swap(shared_lock& u)noexcept; mutex_type* release()noexcept; // observersbool owns_lock()constnoexcept;explicit operatorbool()constnoexcept; mutex_type* mutex()constnoexcept; private: mutex_type* pm;// exposition onlybool owns;// exposition only}; template<class Mutex>void swap(shared_lock<Mutex>& x, shared_lock<Mutex>& y)noexcept;}