std:: system_category
|
Definiert im Header
<system_error>
|
||
|
const
std::
error_category
&
system_category
(
)
noexcept
;
|
(seit C++11) | |
Ruft eine Referenz auf das statische Fehlerkategorieobjekt für Fehler ab, die vom Betriebssystem gemeldet werden. Das Objekt muss die virtuelle Funktion std::error_category::name() überschreiben, um einen Zeiger auf den String "system" zurückzugeben. Es muss ebenfalls die virtuelle Funktion std::error_category::default_error_condition() überschreiben, um die Fehlercodes, die mit POSIX errno -Werten übereinstimmen, auf std::generic_category abzubilden.
Inhaltsverzeichnis |
Parameter
(keine)
Rückgabewert
Eine Referenz auf das statische Objekt mit nicht spezifiziertem Laufzeittyp, abgeleitet von std::error_category .
Hinweise
Unter Windows,
system_category()
bildet typischerweise einige
Windows-Fehlercodes
auf POSIX-Codes ab. Unter POSIX,
system_category()
entspricht tendenziell
std::generic_category()
abgesehen vom Namen.
Beispiel
#include <iomanip> #include <iostream> #include <string> #include <system_error> int main() { for (int const code : {EDOM, 10001}) { const std::error_condition econd = std::system_category().default_error_condition(code); std::cout << "Category: " << econd.category().name() << '\n' << "Value: " << econd.value() << '\n' << "Message: " << econd.message() << "\n\n"; } }
Mögliche Ausgabe:
Category: generic Value: 33 Message: Numerical argument out of domain Category: system Value: 10001 Message: Unknown error 10001
Siehe auch
|
(C++11)
|
identifiziert die generische Fehlerkategorie
(Funktion) |
|
(C++11)
|
die
std::error_condition
Aufzählung, die alle standardmäßigen
<cerrno>
Makrokonstanten auflistet
(Klasse) |