Namespaces
Variants

std:: _Exit

From cppreference.net
Utilities library
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 std::_Exit bereitstellen.

(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)