std::try_lock
De cppreference.com
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 Lockable lock1
, 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.
Ejecuta este código
#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, const char *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) |