Namespaces
Variants

std:: quick_exit

From cppreference.net
Utilities library
Определено в заголовочном файле <cstdlib>
[ [ noreturn ] ] void quick_exit ( int exit_code ) noexcept ;
(начиная с C++11)

Вызывает нормальное завершение программы без полной очистки ресурсов.

Функции, переданные в std::at_quick_exit , вызываются в обратном порядке их регистрации. Если исключение пытается покинуть любую из функций, std::terminate вызывается. После вызова зарегистрированных функций вызывается std::_Exit ( exit_code ) .

Функции, переданные в std::atexit , не вызываются.

Содержание

Параметры

exit_code - статус завершения программы

Возвращаемое значение

(нет)

Пример

#include <cstdlib>
#include <iostream>
template<int N>
void quick_exit_handler()
{
    std::cout << "quick_exit handler #" << N << std::endl; // flush is intended
}
void at_exit_handler()
{
    std::cout << "at_exit handler\n";
}
int main()
{
    if (std::at_quick_exit(quick_exit_handler<1>) ||
        std::at_quick_exit(quick_exit_handler<2>))
    {
        std::cerr << "Registration failed\n";
        return EXIT_FAILURE;
    }
    std::atexit(at_exit_handler); // the handler will not be called
    struct R { ~R() { std::cout << "destructor\n"; } } resource;
    /*...*/
    std::quick_exit(EXIT_SUCCESS);
    std::cout << "This statement is unreachable...\n";
}

Вывод:

quick_exit handler #2
quick_exit handler #1

Смотрите также

вызывает аварийное завершение программы (без очистки)
(функция)
вызывает нормальное завершение программы с очисткой
(функция)
регистрирует функцию для вызова при std::exit() вызове
(функция)
регистрирует функцию для вызова при std::quick_exit вызове
(функция)