std:: quick_exit
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
Определено в заголовочном файле
<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()
вызове
(функция) |
|
|
(C++11)
|
регистрирует функцию для вызова при
std::quick_exit
вызове
(функция) |
|
Документация C
для
quick_exit
|
|