What Is an Exception?

The term exception is shorthand for the phrase "exceptional event."

Definition

An exception is an event that disrupts the normal flow of instructions during the execution of a program.

When an error occurs within a method, the method creates an object and hands it off to the runtime system. The object, called an exception object, [1] contains information about the error, including its type and the state of the program when the error occurred. Creating an exception object and handing it to the runtime system is called throwing an exception.

[1] Exception objects inherit from the Throwable class.

After a method throws an exception, the runtime system attempts to find something to handle it. The set of possible "somethings" to handle the exception is the ordered list of methods that had been called to get to the method where the error occurred. The list of methods is known as the call stack (Figure 75).

Figure 75. The call stack.

The runtime system searches the call stack for a method that contains a block of code that can handle the exception. This block of code is called an exception handler. The search begins with the method in which the error occurred and proceeds through the call stack in the reverse order that the methods were called. When an appropriate handler is found, the runtime system passes the exception to the handler. An exception handler is considered appropriate if the type of the exception object thrown is the same as the type that can be handled by the handler. The exception handler chosen is said to catch the exception. If the runtime system exhaustively searches all the methods on the call stack without finding an appropriate exception handler, the runtime system (and, consequently, the program) terminates (Figure 76).

Figure 76. When an error occurs, the runtime system searches the call stack for an appropriate error handler.

Using exceptions to manage errors has some advantages over traditional error-management techniques. You can learn more in the section Advantages of Exceptions (page 260).

Категории