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
Definiert im Header <future>
class future_error ;
(seit C++11)

Die Klasse std::future_error definiert ein Ausnahmeobjekt, das bei Fehlern von Funktionen in der Thread-Bibliothek geworfen wird, die sich mit asynchroner Ausführung und gemeinsamen Zuständen befassen ( std::future , std::promise , etc.). Ähnlich wie std::system_error trägt diese Ausnahme einen Fehlercode, der mit std::error_code kompatibel ist.

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

Vererbungsdiagramm

Inhaltsverzeichnis

Memberfunktionen

erstellt ein std::future_error Objekt
(öffentliche Elementfunktion)
ersetzt das std::future_error Objekt
(öffentliche Elementfunktion)
gibt den Fehlercode zurück
(öffentliche Elementfunktion)
gibt die erklärende Zeichenkette für den spezifischen Fehlercode zurück
(öffentliche Elementfunktion)

Geerbt von std:: exception

Elementfunktionen

[virtual]
zerstört das Exception-Objekt
(virtuelle öffentliche Elementfunktion von std::exception )
[virtual]
gibt einen erläuternden String zurück
(virtuelle öffentliche Elementfunktion von std::exception )

Beispiel

#include <future>
#include <iostream>
int main()
{
    std::future<int> empty;
    try
    {
        int n = empty.get(); // Das Verhalten ist undefiniert, aber
                             // manche Implementierungen werfen std::future_error
    }
    catch (const std::future_error& e)
    {
        std::cout << "Caught a future_error with code \"" << e.code()
                  << "\"\nMessage: \"" << e.what() << "\"\n";
    }
}

Mögliche Ausgabe:

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

Siehe auch

identifiziert die Future-Fehlercodes
(enum)