std:: quick_exit
From cppreference.net
C++
Utilities library
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Program support utilities
|
ヘッダーで定義
<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
関連項目
|
異常なプログラム終了を引き起こす(クリーンアップなし)
(function) |
|
|
クリーンアップを行った正常なプログラム終了を引き起こす
(function) |
|
|
std::exit()
呼び出し時に実行される関数を登録する
(function) |
|
|
(C++11)
|
std::quick_exit
呼び出し時に実行される関数を登録する
(function) |
|
C documentation
for
quick_exit
|
|