Share via


Unhandled Exceptions

OverviewHow Do IFAQ

If a matching catch handler (or ellipsis catch handler) cannot be found for the current exception, the predefined terminate run-time function is called. (You can also explicitly call terminate in any of your handlers.) The default action of terminate is to call abort. If you want terminate to call some other function in your program before exiting the application, call the set_terminate function with the name of the function to be called as its single argument. You can call set_terminate at any point in your program. The terminate routine always calls the last function given as an argument to set_terminate.

The following example code throws a char * exception, but does not contain a handler designated to catch exceptions of type char *. The call to set_terminate instructs terminate to call term_func:

#include <eh.h>      // For function prototypes
#include <iostream.h>
#include <process.h>

void term_func()
{
    //...
    cout << "term_func was called by terminate." << endl;
    exit( -1 );
 }
int main()
{
    try
    {
        // ...
        set_terminate( term_func );
        // ...
        throw "Out of memory!"; // No catch handler for this exception
    }
    catch( int )
    {
        cout << "Integer exception raised." << endl;
    }
    return 0;
}

After performing any desired cleanup tasks, the term_func function should terminate the program or current thread, ideally by calling exit. If it doesn’t, and instead returns to its caller, abort is called.