Namespaces
Variants

std:: future_error

From cppreference.net
Concurrency support library
Threads
(C++11)
(C++20)
this_thread namespace
(C++11)
(C++11)
Cooperative cancellation
Mutual exclusion
Generic lock management
Condition variables
(C++11)
Semaphores
Latches and Barriers
(C++20)
(C++20)
Futures
(C++11)
(C++11)
(C++11)
(C++11)
future_error
(C++11)
Safe reclamation
Hazard pointers
Atomic types
(C++11)
(C++20)
Initialization of atomic types
(C++11) (deprecated in C++20)
(C++11) (deprecated in C++20)
Memory ordering
(C++11) (deprecated in C++26)
Free functions for atomic operations
Free functions for atomic flags
Definido en el encabezado <future>
class future_error ;
(desde C++11)

La clase std::future_error define un objeto de excepción que es lanzado ante fallos por las funciones en la biblioteca de hilos que manejan ejecución asíncrona y estados compartidos ( std::future , std::promise , etc). Similar a std::system_error , esta excepción transporta un código de error compatible con std::error_code .

cpp/error/exception cpp/error/logic error std-future error-inheritance.svg

Diagrama de herencia

Contenidos

Funciones miembro

crea un objeto std::future_error
(función miembro pública)
reemplaza el objeto std::future_error
(función miembro pública)
devuelve el código de error
(función miembro pública)
devuelve la cadena explicativa específica del código de error
(función miembro pública)

Heredado de std:: exception

Funciones miembro

[virtual]
destruye el objeto de excepción
(función miembro pública virtual de std::exception )
[virtual]
devuelve una cadena explicativa
(función miembro pública virtual de std::exception )

Ejemplo

#include <future>
#include <iostream>
int main()
{
    std::future<int> empty;
    try
    {
        int n = empty.get(); // El comportamiento es indefinido, pero
                             // algunas implementaciones lanzan std::future_error
    }
    catch (const std::future_error& e)
    {
        std::cout << "Caught a future_error with code \"" << e.code()
                  << "\"\nMessage: \"" << e.what() << "\"\n";
    }
}

Salida posible:

Caught a future_error with code "future:3"
Message: "No associated state"

Véase también

identifica los códigos de error de future
(enum)