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