次の方法で共有


terminate (CRT)

set_terminate を使用して指定した関数または呼び出し abort。

void terminate( void );

解説

terminate の関数は C++ 例外処理を除く使用され次の場合に呼び出されます :

  • 一致した catch ハンドラーがスローされた C++ の例外に対して見つけることができません。

  • 例外はスタックでデストラクターのアンワインド関数によってスローされます。

  • スタックが例外をスローした後破損しています。

terminate の呼び出し abort 既定では。独自の終了関数を作成し引数として関数の名前で set_terminate を呼び出すとこの既定値を変更できます。terminate は最後の関数を set_terminate に引数として受け取る呼び出します。詳細については未処理の例外 C++ を参照してください。

必要条件

ルーチン

必須ヘッダー

terminate

<eh.h>

互換性の詳細については、「C ランタイム ライブラリ」の「互換性」を参照してください。

使用例

// crt_terminate.cpp
// compile with: /EHsc
#include <eh.h>
#include <process.h>
#include <iostream>
using namespace std;

void term_func();

int main()
{
    int i = 10, j = 0, result;
    set_terminate( term_func );
    try
    {
        if( j == 0 )
            throw "Divide by zero!";
        else
            result = i/j;
    }
    catch( int )
    {
        cout << "Caught some integer exception.\n";
    }
    cout << "This should never print.\n";
}

void term_func()
{
    cout << "term_func() was called by terminate().\n";

    // ... cleanup tasks performed here

    // If this function does not exit, abort is called.

    exit(-1);
}
  

同等の .NET Framework 関数

該当なし標準 C 関数を呼び出すには、PInvoke を使用します。詳細については、「プラットフォーム呼び出しの例」を参照してください。

参照

関連項目

例外処理ルーチン

abort

_set_se_translator

set_terminate (CRT)

set_unexpected (CRT)

unexpected (CRT)