terminate (CRT)
ユーザーが set_terminateを使用して指定する関数または呼び出し abort。
void terminate( void );
解説
terminate 関数は C++ 例外処理との使用され、次の場合に呼び出され、M:
対応する 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 を使用します。詳細については、「プラットフォーム呼び出しの例」を参照してください。