Compartilhar via


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:

  • Não é possível encontrar um manipulador de captura correspondente 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, consulte Estado global na 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