Espacios de nombres
Variantes
Acciones

std::shared_mutex::lock

De cppreference.com
< cpp‎ | thread‎ | shared 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
Gestión genérica de bloqueo
(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)
Recuperación segura
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++17)

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 en cualquier modalidad (compartido o exclusivo), el comportamiento no está definido.

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.

Los mutex compartidos no soportan una transición directa de la modalidad de propiedad compartida a única/exclusiva: tiene que renunciarse al bloqueo compartido con unlock_shared() antes de que se pueda obtener la propiedad exclusiva con lock(). boost::upgrade_mutex puede usarse para este propósito.

[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_mutexstd::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]
Desbloquea el mutex
(función miembro pública)[editar]
Documentación de C para mtx_lock
close