|
|
Member functions | ||||
Shared locking | ||||
Modifiers | ||||
Observers | ||||
Non-member functions | ||||
Defined in header <shared_mutex> | ||
template<class Mutex> class shared_lock; | (since C++14) | |
The classshared_lock
is a general-purpose shared mutex ownership wrapper allowing deferred locking, timed locking and transfer of lock ownership. Locking ashared_lock
locks the associated shared mutex in shared mode (to lock it in exclusive mode,std::unique_lock can be used).
Theshared_lock
class is movable, but not copyable – it meets the requirements ofMoveConstructible andMoveAssignable but not ofCopyConstructible orCopyAssignable.
shared_lock
meets theLockable requirements. IfMutex
meets theSharedTimedLockable requirements,shared_lock
also meetsTimedLockable requirements.
In order to wait in a shared mutex in shared ownership mode,std::condition_variable_any can be used (std::condition_variable requiresstd::unique_lock and so can only wait in unique ownership mode).
Contents |
Mutex | - | the type of the shared mutex to lock. The type must meet theSharedLockable requirements |
Type | Definition |
mutex_type | Mutex |
constructs ashared_lock , optionally locking the supplied mutex(public member function)[edit] | |
unlocks the associated mutex (public member function)[edit] | |
unlocks the mutex, if owned, and acquires ownership of another (public member function)[edit] | |
Shared locking | |
locks the associated mutex (public member function)[edit] | |
tries to lock the associated mutex (public member function)[edit] | |
tries to lock the associated mutex, for the specified duration (public member function)[edit] | |
tries to lock the associated mutex, until a specified time point (public member function)[edit] | |
unlocks the associated mutex (public member function)[edit] | |
Modifiers | |
swaps the data members with anothershared_lock (public member function)[edit] | |
disassociates the mutex without unlocking (public member function)[edit] | |
Observers | |
returns a pointer to the associated mutex (public member function)[edit] | |
tests whether the lock owns its associated mutex (public member function)[edit] | |
tests whether the lock owns its associated mutex (public member function)[edit] |
(C++14) | specializes thestd::swap algorithm (function template)[edit] |
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 2981 | C++17 | redundant deduction guide fromshared_lock<Mutex> was provided | removed |