std::quick_exit
From cppreference.com
| ヘッダ <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
| |