共用方式為


Exception Processing

When a program executes, a number of abnormal conditions and errors called "exceptions" can occur. These may include running out of memory, resource allocation errors, and failure to find files.

The Microsoft Foundation Class Library uses an exception-handling scheme that is modeled closely after the one proposed by the ANSI standards committee for C++. An exception handler must be set up before calling a function that may encounter an abnormal situation. If the function encounters an abnormal condition, it throws an exception and control is passed to the exception handler.

Several macros included with the Microsoft Foundation Class Library will set up exception handlers. A number of other global functions help to throw specialized exceptions and terminate programs, if necessary. These macros and global functions fall into the following categories:

  • Exception macros, which structure your exception handler

  • Exception-throwing functions, which generate exceptions of specific types

  • Termination functions, which cause program termination

For examples and more details, see the article in Visual C++ Programmer's Guide.

Exception Macros

TRY Designates a block of code for exception processing.
CATCH Designates a block of code for catching an exception from the preceding TRY block.
CATCH_ALL Designates a block of code for catching all exceptions from the preceding TRY block.
AND_CATCH Designates a block of code for catching additional exception types from the preceding TRY block.
AND_CATCH_ALL Designates a block of code for catching all other additional exception types thrown in a preceding TRY block.
END_CATCH Ends the last CATCH or AND_CATCH code block.
END_CATCH_ALL Ends the last CATCH_ALL code block.
THROW Throws a specified exception.
THROW_LAST Throws the currently handled exception to the next outer handler.

Exception-Throwing Functions

AfxThrowArchiveException Throws an archive exception.
AfxThrowFileException Throws a file exception.
AfxThrowMemoryException Throws a memory exception.
AfxThrowNotSupportedException Throws a not-supported exception.
AfxThrowResourceException Throws a Windows resource-not-found exception.
AfxThrowUserException Throws an exception in a user-initiated program action.

MFC provides two exception-throwing functions specifically for OLE exceptions:

OLE Exception Functions

AfxThrowOleDispatchException Throws an exception within an OLE automation function.
AfxThrowOleException Throws an OLE exception.

To support database exceptions, the database classes provide two exception classes, CDBException and CDaoException, and global functions to support the exception types:

DAO Exception Functions

AfxThrowDAOException Throws a CDaoException from your own code.
AfxThrowDBException Throws a CDBException from your own code.

MFC provides the following termination function:

Termination Functions

AfxAbort Called to terminate an application when a fatal error occurs.

See Also   CException