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
Défini dans l'en-tête <future>
class future_error ;
(depuis C++11)

La classe std::future_error définit un objet d'exception qui est lancé en cas d'échec par les fonctions de la bibliothèque de threads qui traitent de l'exécution asynchrone et des états partagés ( std::future , std::promise , etc.). Similaire à std::system_error , cette exception transporte un code d'erreur compatible avec std::error_code .

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

Diagramme d'héritage

Table des matières

Fonctions membres

crée un objet std::future_error
(fonction membre publique)
remplace l'objet std::future_error
(fonction membre publique)
retourne le code d'erreur
(fonction membre publique)
retourne la chaîne explicative spécifique au code d'erreur
(fonction membre publique)

Hérité de std:: exception

Fonctions membres

[virtual]
détruit l'objet exception
(fonction membre publique virtuelle de std::exception )
[virtual]
retourne une chaîne explicative
(fonction membre publique virtuelle de std::exception )

Exemple

#include <future>
#include <iostream>
int main()
{
    std::future<int> empty;
    try
    {
        int n = empty.get(); // Le comportement est indéfini, mais
                             // certaines implémentations lancent std::future_error
    }
    catch (const std::future_error& e)
    {
        std::cout << "Caught a future_error with code \"" << e.code()
                  << "\"\nMessage: \"" << e.what() << "\"\n";
    }
}

Sortie possible :

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

Voir aussi

identifie les codes d'erreur des futures
(enum)