javaexceptionunchecked-exception

Is there an advantage to declaring that a method throws an unchecked exception?


If I have a method which throws an unchecked exception, e.g.:

void doSomething(int i) {
  if (i < 0) throw new IllegalArgumentException("Too small");
  // ...
}

is there any advantage to explicitly declaring that the method throws the exception, i.e.

void doSomething(int i) throws IllegalArgumentException {
  if (i < 0) throw new IllegalArgumentException("Too small");
  // ...
}

as opposed to (or in addition to) describing the behaviour in javadoc:

/**
 * This method does something useful.
 * @param i some input value
 * @throws IllegalArgumentException if {@code i < 0}
 */
void doSomething(int i) {
  if (i < 0) throw new IllegalArgumentException("Too small");
  // ...
}

The reasons why I would claim it is not useful to have the throws are:

The reasons why I would claim it would be useful to have the throws are:

In short, I think that throws is unnecessary, but a javadoc description via @throws is useful. I would be interested to know others' opinion on this.


Solution

  • When you state that a method throws an exception you are saying to the caller:

    You have two choices:

    1. Redeclare yourself as throwing the same exception.
    2. Catch the exception and deal with it.

    In case 1 it may remind user to implement a finally - which could be a bonus.

    In case 2 it focuses the mind on the exception which could also be a bonus.

    If you hide that possibility then neither of the above reminders occur to the user.

    To me one may unnecessarily clutter up their code while the other keeps it sweet and simple. However, one encourages focus on potential issues while the other may leave you in blissful ignorance.

    Bottom line - Ask yourself how irritating it will be to declare the exception as thrown (e.g. should you declare throws NullPointerException? - NO!) and is this irritation balanced by the upside of focusing the users mind on catch, finally and throws.