Condividi tramite


terminate (CRT)

Chiama abort o una funzione specificata con set_terminate.

Sintassi

void terminate( void );

Osservazioni:

La funzione terminate viene usata con la gestione delle eccezioni C++ e viene chiamata nei casi seguenti:

  • Non è possibile trovare un gestore catch corrispondente per un'eccezione C++ generata.

  • Viene generata un'eccezione da una funzione distruttore durante la rimozione dello stack.

  • Lo stack risulta danneggiato dopo la generazione di un'eccezione.

terminate chiama abort per impostazione predefinita. È possibile modificare questo comportamento predefinito scrivendo una funzione di terminazione personalizzata e chiamando set_terminate con il nome della funzione come argomento. terminate chiama l'ultima funzione fornita come argomento a set_terminate. Per altre informazioni, vedere Eccezioni C++ non gestite.

Per impostazione predefinita, lo stato globale di questa funzione è limitato all'applicazione. Per modificare questo comportamento, vedere Stato globale in CRT.

Requisiti

Ciclo Intestazione obbligatoria
terminate <eh.h>

Per altre informazioni sulla compatibilità, vedere Compatibility (Compatibilità).

Esempio

// 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().

Vedi anche

Routine di gestione delle eccezioni
abort
_set_se_translator
set_terminate
set_unexpected
unexpected