std::recursive_timed_mutex::try_lock_until
From cppreference.com
< cpp | thread | recursive timed mutex
| template< class Clock, class Duration >
bool try_lock_until( const std::chrono::time_point<Clock,Duration>& timeout_time ); |
(since C++11) | |
Tries to lock the mutex. Blocks until specified timeout_time has been reached or the lock is acquired, whichever comes first. On successful lock acquisition returns true, otherwise returns false.
The clock tied to timeout_time is used, which means that adjustments of the clock are taken into account. Thus, the maximum duration of the block might, but might not, be less or more than timeout_time - Clock::now() at the time of the call, depending on the direction of the adjustment. The function also may block for longer than until after timeout_time has been reached due to scheduling or resource contention delays.
Contents |
[edit] Parameters
| timeout_time | - | maximum time point to block until |
[edit] Return value
true if the lock was acquired successfully, otherwise false.
[edit] Exceptions
| This section is incomplete |
[edit] Example
This example shows a two minute block
#include <iostream> #include <ctime> #include <chrono> #include <mutex> int main() { std::timed_mutex test; test.try_lock(); auto now=std::chrono::steady_clock::now(); test.try_lock_until(now+std::chrono::minutes(2)); std::cout << "hello world"; }
[edit] See also
| 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) |
|
| unlocks the mutex (public member function) |
|