std::unique_lock::try_lock_until
De cppreference.com
< cpp | thread | unique lock
template< class Clock, class Duration > bool try_lock_until( const std::chrono::time_point<Clock,Duration>& timeout_time ); |
(desde C++11) | |
Intenta bloquear el mutex asociado (es decir, tomar posesión). Se bloquea hasta que se alcance el tiempo de espera timeout_time
o se adquiera el cerrojo, lo que suceda primero. Devuelve true si la adquisición del cerrojo tuvo éxito, de lo contrario devuelve false. Puede bloquearse por un período más largo hasta que se alcance el tiempo de espera timeout_time
.
Efectivamente llama a mutex()->try_lock_until(timeout_time)
Se lanza std::system_error si no hay un mutex asociado o si el mutex ya está bloqueado por el mismo hilo.
Clock
debe cumplir con los requerimientos de Clock. El programa está mal formado si std::chrono::is_clock_v<Clock> es false. (desde C++20)
Contenido |
[editar] Parámetros
timeout_time | - | Punto de tiempo máximo hasta el cual bloquearse. |
[editar] Valor de retorno
true si se tuvo éxito al tomar posesión del mutex; de lo contrario, false.
[editar] Excepciones
- Cualquier excepción lanzada por mutex()->try_lock_until(timeout_time).
- Si no hay un mutex asociado, std::system_error con un código de error de std::errc::operation_not_permitted.
- Si el mutex ya está bloqueado, std::system_error con un código de error de std::errc::resource_deadlock_would_occur.
[editar] Ejemplo
Esta sección está incompleta Razón: sin ejemplo |
[editar] Véase también
Bloquea el mutex asociado (es decir, toma posesión). (función miembro pública) | |
Intenta bloquear el mutex asociado (es decir, tomar posesión) sin bloquearse. (función miembro pública) | |
Intenta bloquear el mutex TimedLockable asociado; es decir, de tomar posesión. Regresa si el mutex no ha estado disponible por la duración de tiempo especificada. (función miembro pública) | |
Desbloquea el mutex asociado; es decir, libera su posesión. (función miembro pública) |