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
Определено в заголовке <future>
class future_error ;
(начиная с C++11)

Класс std::future_error определяет объект исключения, который выбрасывается при сбое функциями библиотеки потоков, работающими с асинхронным выполнением и разделяемыми состояниями ( std::future , std::promise и др.). Подобно std::system_error , это исключение содержит код ошибки, совместимый с std::error_code .

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

Диаграмма наследования

Содержание

Функции-члены

создает объект std::future_error
(public member function)
заменяет объект std::future_error
(public member function)
возвращает код ошибки
(public member function)
возвращает пояснительную строку, специфичную для кода ошибки
(public member function)

Унаследовано от std:: logic_error

Унаследовано от std:: exception

Функции-члены

уничтожает объект исключения
(виртуальная публичная функция-член std::exception )
[virtual]
возвращает поясняющую строку
(виртуальная публичная функция-член std::exception )

Пример

#include <future>
#include <iostream>
int main()
{
    std::future<int> empty;
    try
    {
        int n = empty.get(); // Поведение не определено, но
                             // некоторые реализации выбрасывают std::future_error
    }
    catch (const std::future_error& e)
    {
        std::cout << "Caught a future_error with code \"" << e.code()
                  << "\"\nMessage: \"" << e.what() << "\"\n";
    }
}

Возможный вывод:

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

Смотрите также

идентифицирует коды ошибок future
(enum)