std:: _Exit
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Program termination | |||||||||||||||||||||
|
|||||||||||||||||||||
| Unreachable control flow | |||||||||||||||||||||
|
(C++23)
|
|||||||||||||||||||||
| Communicating with the environment | |||||||||||||||||||||
| Signals | |||||||||||||||||||||
| Signal types | |||||||||||||||||||||
| Non-local jumps | |||||||||||||||||||||
| Types | |||||||||||||||||||||
|
Definiert im Header
<cstdlib>
|
||
|
[
[
noreturn
]
]
void
_Exit
(
int
exit_code
)
noexcept
;
|
(seit C++11) | |
Verursacht ein normales Programmende, ohne die Ressourcen vollständig zu bereinigen.
Destruktoren von Variablen mit automatischer, thread-lokaler und statischer Speicherdauer werden nicht aufgerufen. Funktionen, die an std::at_quick_exit() oder std::atexit() übergeben wurden, werden nicht aufgerufen. Ob geöffnete Ressourcen wie Dateien geschlossen werden, ist implementierungsdefiniert.
Wenn
exit_code
0
oder
EXIT_SUCCESS
ist, wird ein implementierungsdefinierter Status zurückgegeben, der eine erfolgreiche Beendigung an die Host-Umgebung signalisiert. Wenn
exit_code
EXIT_FAILURE
ist, wird ein implementierungsdefinierter Status zurückgegeben, der eine
nicht erfolgreiche
Beendigung anzeigt. In anderen Fällen wird ein implementierungsdefinierter Statuswert zurückgegeben.
|
Eine freistehende Implementierung muss
|
(since C++23) |
Inhaltsverzeichnis |
Parameter
| exit_code | - | Beendigungsstatus des Programms |
Rückgabewert
(keine)
Hinweise
Obwohl
_Exit
seit C++23 freistehend sein muss, ist es nicht erforderlich, dass es in einer freistehenden C-Implementierung verfügbar ist.
Beispiel
#include <iostream> class Static { public: ~Static() { std::cout << "Static dtor\n"; } }; class Local { public: ~Local() { std::cout << "Local dtor\n"; } }; Static static_variable; // Destruktor dieses Objekts wird *nicht* aufgerufen void atexit_handler() { std::cout << "atexit handler\n"; } int main() { Local local_variable; // Destruktor dieses Objekts wird *nicht* aufgerufen // Handler wird *nicht* aufgerufen const int result = std::atexit(atexit_handler); if (result != 0) { std::cerr << "atexit registration failed\n"; return EXIT_FAILURE; } std::cout << "test" << std::endl; // Flush durch std::endl // muss hier stehen, sonst wird nichts ausgegeben std::_Exit(EXIT_FAILURE); }
Ausgabe:
test
Siehe auch
|
verursacht abnormale Programmbeendigung (ohne Bereinigung)
(Funktion) |
|
|
verursacht normale Programmbeendigung mit Bereinigung
(Funktion) |
|
|
C-Dokumentation
für
_Exit
|
|