What does a checked exception mean?

In this Java exceptions tutorial, learn what is an exception in Java, the difference between a checked exception and an unchecked exception. We will also learn some Java exception handling best practices.

1. What is Exception in Java?

“An exception is an unexpected event that occurred during the execution of a program, and disrupts the normal flow of instructions.”

  • In Java, all errors and exceptions are of type with Throwable class.
  • When an error occurs within a method, the method creates an object (or any subtype of Throwable) and hands it off to the runtime system. This object is called the exception object.
  • The exception object contains the information about the error, including exception 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.

A few examples of an exception in the program execution can be:

  • User entered alphanumeric input and program excepts numeric input.
  • Program tries to read file but the file does not exist in specified location.
  • A network connection terminated while reading data from a webservice.
try {
    Integer.parseInt("six") ;          //This line throws an exception
}
catch(NumberFormatException nfe) {
    //handle exception
}

2. Handling a Thrown Exception

We have two choices when an exception object is created in our application;

  • Either we will handle it within method using the try-catch block.
  • Or we can pass it to the caller method to let it handle.

This is a very important decision to be made while setting the responsibilities of a method.

A method should clearly indicate that what all exceptions it will handle and which it will not. It is defined in the method declaration using the throws keyword.

To handle the exception, We must catch the exception in catch section of try-catch block.

try {
    //code
}
catch(Exception e) {
    //handle exception
}

If an exception is not handled in the application, then it will propagate to the JVM. The JVM usually terminates the program.

3. Checked Exception vs Unchecked Exception

3.1. Exception Hierarchy

In Java, exceptions are broadly categorized into two sections:

  • Checked exceptions
  • Unchecked exceptions

What does a checked exception mean?

3.2. Checked Exceptions

Java checked exceptions are those exceptions, as the name suggests, which a method must handle in its body or throw to the caller method so the caller method can handle it.

Checked exceptions are checked by the Java compiler so they are called compile time exceptions.

Java compiler forces us to handle these exceptions in some manner in the application code. We must handle these exceptions at a suitable level inside the application so that we can inform the user about the failure and ask him to retry or come later.

Generally, checked exceptions denote error scenarios that are outside the immediate control of the program. These occur usually interacting with other systems/network resources e.g. database errors, network connection errors, missing files, etc.

Note that all checked exceptions are subclasses of Exception class. For example,

  • ClassNotFoundException
  • IOException
  • SQLException

Checked Exception Example

FileNotFoundException is a checked exception in Java. Anytime, we want to read a file from the filesystem, Java forces us to handle an error situation where the file may not be present in the place.

public static void main(String[] args)
{
    FileReader file = new FileReader("somefile.txt");
}

In the above example, you will get compile-time error with the message – Unhandled exception type FileNotFoundException.

To make the program able to compile, we must handle this error situation in the try-catch block. Below given code will compile absolutely fine.

public static void main(String[] args)
{
    try
    {
		FileReader file = new FileReader("somefile.txt");
	}
    catch (FileNotFoundException e)
    {
    	//Alternate logic
		e.printStackTrace();
	}
}

3.3. Unchecked Exception

Unchecked exceptions are not checked by the compiler. These are called runtime exceptions.

Unchecked exceptions will come into life and occur in the program, once any buggy code is executed.

In Java, a member method is not forced by the compiler to declare the unchecked exceptions into the method declaration. Generally, such methods almost always do not declare them.

Unchecked Exceptions are subclasses of RuntimeException class.

  • ArithmeticException
  • ArrayStoreException
  • ClassCastException

The strange thing is that RuntimeException is itself subclass of Exception i.e. all unchecked exception classes should have been checked exceptions implicitly, BUT they are not.”

Unchecked Exception Example

The code in the given program does not give any compile-time error. But when we run the example, it throws NullPointerException. NullPointerException is an unchecked exception in Java.

public static void main(String[] args)
{
    try
    {
		FileReader file = new FileReader("pom.xml");

		file = null;

		file.read();
	}
    catch (IOException e)
    {
    	//Alternate logic
		e.printStackTrace();
	}
}

3. Exception Handling Best Practices

  • Checked exceptions can be used when a method may fail to do what it must. For example, a method named prepareSystem() which pre-populates configuration files and does some configuration using them. It can declare throwing FileNotFoundException which implies that the method uses configuration files from the file system and they are missing.
  • Checked exceptions ideally should never be used for programming errors, but absolutely should be used for resource errors and for flow control in such cases.
    Throw only those exceptions which a method can not handle by any means. The method should first try to handle it as soon as it encounters. Throw the exception only if it is not possible to handle it inside the method.
  • A good way to define method signatures is to declare exceptions close to method name. If the method is named openFile(), then it is expected to throw FileNotFoundException?. If the method is named findProvider(), then it is expected to throw NoSuchProviderException.
  • Also, these type of exceptions should be made checked exceptions as it forces the caller to deal with the problems that are inherent to the semantic of the methods.

  • If we are creating any custom exception then the rule is if a client can reasonably be expected to recover from an exception, make it a checked exception. If a client cannot do anything to recover from the exception, make it an unchecked exception.

In reality, most applications will have to recover from pretty much all exceptions including NullPointerException, IllegalArgumentExceptions and many other unchecked exceptions. The action/transaction that failed will be aborted but the application has to stay alive and be ready to serve the next action/transaction.

The only time it is normally legal to shut down an application is during startup. For example, if a configuration file is missing and the application cannot do anything sensible without it, then it is legal to shut down the application.

4. Conclusion

In this Java tutorial, we learned about Java exceptions. We learned the difference between checked vs unchecked exceptions in Java, along with how to handle unchecked exceptions, exception hierarchy in Java with examples.

Remember the biggest difference between checked and unchecked exceptions is that checked exceptions are forced by the compiler and used to indicate exceptional conditions that are out of the control of the program, while unchecked exceptions are occurred during runtime and are used to indicate programming errors.

Happy Learning !!

What is an example of a checked exception?

ClassNotFoundException, IOException, SQLException etc are the examples of the checked exceptions.

Are checked exceptions good?

Checked exceptions leads to annoying boilerplate code ( try {} catch () {} ). Every time you call a method that throws a checked exception, you have to write the try-catch-statement. The compiler forces us to catch the exception. Often this ends up in a mixing of main logic and error handling.

Why do we need checked exceptions?

If a client can reasonably be expected to recover from an exception, make it a checked exception. If a client cannot do anything to recover from the exception, make it an unchecked exception.” In this way, we can recover the system by accepting another user input file name.

What are checked and unchecked exceptions examples?

Compare checked vs. unchecked exceptions.