|
| |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| 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 |