Exception Handling Program in Java

Exception means something that is abnormal. In Java, an exception is treated as a problem that disrupts the normal flow of the program. An exception leads to abnormal termination of the Java program. There can be many scenarios where an exception can occur. A few of them are mentioned below.

  • When a number is divided by zero, for example, int x = 6 / 0; This statement is syntactically correct, but zero can never divide a number mathematically. Hence, an exception is raised.
  • Connecting to a server, but the server is off.
  • Opening a file, but the file is already deleted by someone.
  • Accessing the index that is not present in the array.
    For example, in the statement int arr[] = {7, 8, 9};, the array contains three elements arr[0], arr[1], arr[2], but if someone tries to access arr[10], then it is not possible as 10th index is not present in the array leading to the generation of an exception.
  • When JVM has run out of memory.
  • User is entering some invalid data. For example, someone types 1342 when asked to write his/ her name.

Some of the exception scenarios mentioned above are due to programmer error; some are due to failure of the resources, while others are due to user error.The exception handling program in Java demonstrates how to handle exceptions in order to maintain the natural flow of the program.

Hierarchical Structure of Exception in Java

Hierarchical Structure of Exception in Java

All classes of exception are derived from the class java.lang.Exception, while the Exception class itself is the child class of the class Throwable. Errors are also the subtypes of the class Throwable.

The need of handling an Exception

Suppose there are 8 statements in a Java program, and an exception has occurred at the 4th statement. Due to exception, the normal flow of the program is interrupted that leads to abnormal termination of the program. Thus, the statements that are coming after the 4th statement never get executed. To ensure that statements after the 4th statement are executed, or to ensure the normal flow of the program, it is required to handle the exception that is raised due to the 4th statement.

Types of Exception in Java

Exceptions in Java can be categorized into the following three categories:

1) Checked Exception

2) Unchecked Exception

3) Error

Let’s discuss each type of exception in detail.

Checked Exception

Checked exceptions are those exceptions that are notified or handled during compile time. Therefore, these exceptions are also called the compile-time exception. These exceptions can never be ignored as it is generated during the compile-time. For example, if we try to access a file that is not present, it thows FileNotFoundException. Consider the following code.

FileName: FileNotFoundExceptionDemo.Java

Upon compilation, the following exceptions are raised.

Output:

Explanation: We have seen that we never reached the execution stage because exceptions are raised during the compilation stage.  The methods read(), and close() are the methods of the class FileReader. These methods throw IOException, and the same has been notified by the Java compiler in the output.

Eliminating Checked Exception

We can use a try-catch block to eliminate the exceptions that came in the above-written program. The following code illustrates the same.

FileName: ExceptionHandleDemo.Java

Output:

Explanation: We have seen because of the statement fr = new FileReader(fileObj); FileNotFoundException is thrown. To handle the exception, the statement fr = new FileReader(fileObj); is put inside the try block, and the raised Exception is handled in the catch block. Similarly, NullPointerException and IOException are also handled. Observe that this time the termination of the program happened normally.

Unchecked Exception

Exceptions that are generated during the execution are called unchecked exception. These exceptions are also known as runtime Exception. These exceptions mainly occur because of some mistakes (logical mistakes, not proper usage of the API) done by the programmer/ developer. For example, if an array is declared of size 7, and the program is trying the access the 8th element, it generates an exception. The following program illustrates the same.

FileName: ArrayIndexExample.Java

Output:

Explanation: In the array, the memory is allocated for the seven integers i.e. 0 to 6. Therefore, the 8th index goes beyond the range of indices of the array arr[]. Hence, we get the exception java.lang.ArrayIndexOutOfBoundsException. If we look at the code syntactically, we find that the statement System.out.println(“The 8th index of the array is ” + arr[8] ); is correct. The Java compiler interprets that the code is accessing the element that is present at the 8th index. However, the Java compiler has no idea about the memory allocation of the array. This is because memory allocation happens at the run-time. Therefore, we get the exception java.lang.ArrayIndexOutOfBoundsException at the run-time.

Handling Unchecked Exception

Similar to handling a checked exception, a try-catch blocks come in handy in handling unchecked too. The java.lang.ArrayIndexOutOfBoundsException raised in the above program can be handled by the following program.

FileName: ExceptionHandleDemo1.Java

Output:

Explanation: This time also the statement that is responsible for raising the ArrayIndexOutOfBoundsException has been put inside a try block. The raised exception is then handled in the catch block.

Errors

Errors are not exceptions. Errors are those problems that are out of the reach of the developers. Errors are not given that much importance because one can hardly do anything about them. Generally, a program can never recover from an error. In other words, errors are not recoverable. Errors occur when there are severe failures. A few of the errors generated by Java environments are VirtualMachineError, OutOfMemoryError, AsserstionError, etc.

Pin It on Pinterest

Share This