terminate (CRT)

chiamate abort o una funzione specificata tramite set_terminate.

void terminate( void );

Note

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

  • Un gestore catch corrispondente non è disponibile per un'eccezione C++.

  • Un'eccezione viene generata da una funzione distruttore durante lo stack viene rimosso.

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

terminate chiamate abort per impostazione predefinita.È possibile modificare questa impostazione predefinita scrivendo diventi proprietaria della funzione di chiusura e chiamando set_terminate con il nome della funzione come argomento.terminate chiama l'ultima funzione fornita come argomento a set_terminate.Per ulteriori informazioni, vedere eccezioni non gestite di C++.

Requisiti

routine

Intestazione di associazione

terminate

<eh.h>

per informazioni di compatibilità aggiuntive, vedere compatibilità nell'introduzione.

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);
}
  

Equivalente .NET Framework

Non applicabile. Per chiamare la funzione c standard, utilizzare PInvoke. Per ulteriori informazioni, vedere Esempi di pinvoke.

Vedere anche

Riferimenti

Routine di gestione delle eccezioni

abort

_set_se_translator

set_terminate (CRT)

set_unexpected (CRT)

unexpected (CRT)