terminate
(CRT)
Chama abort
ou uma função especificada usando set_terminate
.
Sintaxe
void terminate( void );
Comentários
A função terminate
é usada com o tratamento de exceção C++ e é chamada nos seguintes casos:
Um manipulador catch correspondente não pode ser encontrado para uma exceção C++ lançada.
Uma exceção é gerada por uma função do destruidor durante o desenrolamento da pilha.
A pilha é corrompida depois de gerar uma exceção.
terminate
chama abort
por padrão. Você pode alterar esse padrão escrevendo sua própria função de encerramento e chamar set_terminate
com o nome da sua função como seu argumento. terminate
chama a última função fornecida como um argumento para set_terminate
. Para obter mais informações, consulte Exceções do C++ sem tratamento.
Por padrão, o estado global dessa função tem como escopo o aplicativo. Para alterar esse comportamento, confira Estado global no CRT.
Requisitos
Rotina | Cabeçalho necessário |
---|---|
terminate |
<eh.h> |
Para obter informações sobre compatibilidade, consulte Compatibilidade.
Exemplo
// 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);
}
term_func() was called by terminate().
Confira também
Rotinas de tratamento de exceções
abort
_set_se_translator
set_terminate
set_unexpected
unexpected