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
(C++11)
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)
(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
 
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.

#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) [editar]