std::try_lock
De cppreference.com
<tbody>
</tbody>
| 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.
Parámetros
| lock1, lock2, ... , lockn | - | Los objetos Lockable a bloquear. |
Valor de retorno
-1 si se tiene éxito, o el valor del índice basado en cero del objeto que no se pudo bloquear.
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
Véase también
(C++11) |
Bloquea los mutex especificados. Se bloquea si ninguno está disponible. (plantilla de función) |