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

関連項目

異常なプログラム終了を引き起こす(クリーンアップなし)
(function)
クリーンアップを行った正常なプログラム終了を引き起こす
(function)
std::exit() 呼び出し時に実行される関数を登録する
(function)
std::quick_exit 呼び出し時に実行される関数を登録する
(function)
C documentation for quick_exit