Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Excerpt

Temporary; see See also BITMAG-138@jira

For the prototype we will lean on the Effective Java Exceptions guidelines (the reference bam thinks kfc was talking about).

A few practical implications are reiterated here.

  • Only throw checked exceptions (contingencies) when the immediately surrounding method is expected to handle it.
    • This could be an alternative control flow (a method may return an integer or throw an exception as alternative return value)
    • Always document the exception
    • Always handle the exception in the immediately surrounding method. If the exception needs to be rethrown, wrap it in a runtime exception (fault)
  • Throw unchecked exceptions (faults) for everything else
    • This could be I/O errors, faulty parameters, invalid invariants (programming errors), etc.
    • Never document the exception on the method. Document it in the exceptions documentation (For instance: "This exception may be thrown by any method on I/O trouble") and/or in the package description (For instance: "Any method in this package may throw IllegalArgumentException" on parameters that are null or the empty string, if not otherwise documented")
    • Catch faults at well defined points in the code by using Fault Barriers. These may catch all runtime exceptions, or a well defined subset. Fault barriers may handle the exception (for instance retry), report it (for instance log it or åresent (a version of) it to the user), or explicitly silence it if it is known to be harmless.
    • Always install a Fault Barrier at the outermost method of a thread, either explicitly or implicitly created (for instance in main(), Thread.run(), and methods in a new thread by frameworks such as Servlets, Web Service frameworks or JMS)

For the pilot, we will may extend the strategy. We will consider

...