Espacios de nombres
Variantes
Acciones

std::try_lock

De cppreference.com
< cpp‎ | thread
 
 
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)
try_lock
(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
 
Definido en el archivo de encabezado <mutex>
template<class Lockable1, class Lockable2, class... LockableN>
int try_lock( Lockable1& lock1, Lockable2& lock2, LockableN&... lockn);
(desde C++11)

Intenta bloquear cada uno de los objetos Lockablelock1, lock2, ..., lockn llamando a try_lock en orden, empezando con el primero.

Si una llamada a try_lock falla, no se realiza ninguna otra llamada a try_lock, se llama a unlock para cualquier objeto bloqueado y se devuelve el índice basado en cero del objeto que no se pudo bloquear.

Si una llamada a try_lock da como resultado una excepción, se llama a unlock para cualquier objeto bloqueado antes de volver a lanzar.

Contenido

[editar]Parámetros

lock1, lock2, ... , lockn - Los objetos Lockable a bloquear.

[editar]Valor de retorno

-1 si se tiene éxito, o el valor del índice basado en cero del objeto que no se pudo bloquear.

[editar]Ejemplo

El siguiente ejemplo utiliza a std::try_lock para contar y restablecer periódicamente los contadores que se ejecutan en hilos/subprocesos separados.

#include <mutex>#include <vector>#include <thread>#include <iostream>#include <functional>#include <chrono>   int main(){int foo_count =0;std::mutex foo_count_mutex;int bar_count =0;std::mutex bar_count_mutex;int overall_count =0;bool done =false;std::mutex done_mutex;   auto increment =[](int&counter, std::mutex&m, constchar*desc){for(int i =0; i <10;++i){std::unique_lock<std::mutex> lock(m);++counter;std::cout<< desc <<": "<< counter <<'\n'; lock.unlock();std::this_thread::sleep_for(std::chrono::seconds(1));}};   std::thread increment_foo(increment, std::ref(foo_count), std::ref(foo_count_mutex), "foo");std::thread increment_bar(increment, std::ref(bar_count), std::ref(bar_count_mutex), "bar");   std::thread update_overall([&](){ done_mutex.lock();while(!done){ done_mutex.unlock();int result = std::try_lock(foo_count_mutex, bar_count_mutex);if(result ==-1){ overall_count += foo_count + bar_count; foo_count =0; bar_count =0;std::cout<<"en general: "<< overall_count <<'\n'; foo_count_mutex.unlock(); bar_count_mutex.unlock();}std::this_thread::sleep_for(std::chrono::seconds(2)); done_mutex.lock();} done_mutex.unlock();});   increment_foo.join(); increment_bar.join(); done_mutex.lock(); done =true; done_mutex.unlock(); update_overall.join();   std::cout<<"Procesamiento terminado\n"<<"foo: "<< foo_count <<'\n'<<"bar: "<< bar_count <<'\n'<<"en general: "<< overall_count <<'\n';}

Posible salida:

bar: 1 foo: 1 foo: 2 bar: 2 foo: 3 en general: 5 bar: 1 foo: 1 bar: 2 foo: 2 bar: 3 en general: 10 bar: 1 foo: 1 bar: 2 foo: 2 en general: 14 bar: 1 foo: 1 bar: 2 en general: 17 foo: 1 bar: 1 foo: 2 en general: 20 Procesamiento terminado foo: 0 bar: 0 en general: 20

[editar]Véase también

(C++11)
Bloquea los mutex especificados. Se bloquea si ninguno está disponible.
(plantilla de función)[editar]
close