std::timed_mutex
From cppreference.com
                    
                                        
                    
                    
                                                            
                    | Defined in header  <mutex> | ||
| class timed_mutex; | (since C++11) | |
The timed_mutex class is a synchronization primitive that can be used to protect shared data from being simultaneously accessed by multiple threads. 
In a manner similar to mutex, timed_mutex offers exclusive, non-recursive ownership semantics.  In addition, timed_mutex provides the ability to attempt to claim ownership of a timed_mutex with a timeout via the try_lock_for() and try_lock_until() methods.
The timed_mutex class satisfies all requirements of TimedMutex and StandardLayoutType.
| Contents | 
[edit] Member types
| Member type | Definition | 
| native_handle_type | implementation-defined | 
[edit] Member functions
| constructs the mutex (public member function) | |
| destroys the mutex (public member function) | |
| operator= [deleted] | not copy-assignable (public member function) | 
| Locking | |
| locks the mutex, blocks if the mutex is not available (public member function) | |
| tries to lock the mutex, returns if the mutex is not available (public member function) | |
| tries to lock the mutex, returns if the mutex has been unavailable for the specified timeout duration (public member function) | |
| tries to lock the mutex, returns if the mutex has been unavailable until specified time point has been reached (public member function) | |
| unlocks the mutex (public member function) | |
| Native handle | |
| returns the underlying implementation-defined thread handle (public member function) | |


