名前空間
変種
操作

std::quick_exit

From cppreference.com
 
 
ユーティリティライブラリ
言語サポート
型のサポート (基本型、RTTI)
ライブラリ機能検査マクロ (C++20)
プログラムユーティリティ
可変引数関数
コルーチンサポート (C++20)
契約サポート (C++26)
三方比較
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

汎用ユーティリティ
関係演算子 (C++20で非推奨)
 
 
ヘッダ <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の呼び出し時に呼び出される関数を登録します。
(関数) [編集]
English 日本語 中文(简体) 中文(繁體)