Espacios de nombres
Variantes
Acciones

std::timed_mutex::lock

De cppreference.com
< cpp‎ | thread‎ | timed mutex
 
 
Biblioteca de apoyo de concurrencia
Hilos
(C++11)
(C++20)
Espacio de nombres this_thread
(C++11)
(C++11)
(C++11)
Cancelación cooperativa
Exclusión mutua
(C++11)
Gestión genérica de bloqueo
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
Variables de condición
(C++11)
Semáforos
Pestillos y barreras
(C++20)
(C++20)
Futuros
(C++11)
(C++11)
(C++11)
(C++11)
Recuperación segura
(C++26)
Punteros de riesgo
Tipos atómicos
(C++11)
(C++20)
Inicialización de tipos atómicos
(C++11)(en desuso en C++20)
(C++11)(en desuso en C++20)
Orden de memoria
Funciones independientes para operaciones atómicas
Funciones independientes para indicadores atómicos
 
 
void lock();
(desde C++11)

Bloquea el mutex. Si otro hilo ya bloqueó el mutex, una llamada a lock bloqueará la ejecución hasta que se adquiera el cerrojo.

Si se llama a lock por un hilo que ya posee el mutex, el comportamiento no está definido: por ejemplo, el programa puede entrar en una condición de interbloqueo. Se recomienda que una implementación que pueda detectar el uso no válido lance un std::system_error con una condición de error resource_deadlock_would_occur en lugar de interbloqueo.

Las operaciones unlock() anteriores en el mismo mutex se sincronizan-con esta operación (como se define en std::memory_order).

Contenido

[editar] Parámetros

(Ninguno)

[editar] Valor de retorno

(Ninguno)

[editar] Excepciones

Lanza std::system_error cuando ocurren errores, incluyendo errores del sistema operativo subyacente que previenen a lock cumplir con sus especificaciones. El mutex no está bloqueado en caso que se lance cualquier excepción.

[editar] Notas

lock() habitualmente no se llama directamente: std::unique_lock, std::scoped_lock, y std::lock_guard se usan para gestionar bloqueo exclusivo.


[editar] Ejemplo

Este ejemplo muestra cómo lock y unlock pueden usarse para proteger datos compartidos.

#include <iostream>
#include <chrono>
#include <thread>
#include <mutex>
 
int g_num = 0;  // protegida por g_num_mutex
std::mutex g_num_mutex;
 
void slow_increment(int id) 
{
    for (int i = 0; i < 3; ++i) {
        g_num_mutex.lock();
        ++g_num;
        std::cout << id << " => " << g_num << '\n';
        g_num_mutex.unlock();
 
        std::this_thread::sleep_for(std::chrono::seconds(1));
    }
}
 
int main()
{
    std::thread t1(slow_increment, 0);
    std::thread t2(slow_increment, 1);
    t1.join();
    t2.join();
}

Posible salida:

0 => 1
1 => 2
0 => 3
1 => 4
0 => 5
1 => 6

[editar] Véase también

Intenta bloquear el mutex; regresa si el mutex no está disponible
(función miembro pública) [editar]
Intenta bloquear el mutex; regresa si el mutex no ha estado
disponible durante el tiempo de espera especificado
(función miembro pública) [editar]
Intenta bloquear el mutex; regresa si el mutex no ha estado
disponible hasta que se haya alcanzado el punto de tiempo especificado
(función miembro pública) [editar]
Desbloquea el mutex
(función miembro pública) [editar]
Documentación de C para mtx_lock