Error Handling Overview
Some processes can generate errors despite the most skillful coding. Disk I/O is one example. (User enters name of a file that doesn't exist. Data cannot be written because the disk is full.) I first met try/catch logic in the mid '90s in Java as a way to handle these sorts of errors. This is now a feature of most mainstream languages.
The basic idea is to surround a block of code (such as disk I/O code) with a "try this" instruction. Following the block to try there is an "if an error occurred" block. Some languages, Java included have an optional "whether or not there was an error do this" block. Code in the "try this" block (including, importantly, subroutines called in that block) can "throw" an error, often an Error or Exception object for use in the "if an error occurred" block.
Error Handling in Java
This is the basic Java syntax:
try {
}
catch (Type1ExceptionOrError var1) {
}
[catch (Type2ExceptionOrError var2) {
}]...
[finally {
}]
Java has both
XxxException and XxxError classes. The builtin classes can be extended by the programmers to create more Exceptions and Errors. Multiple catch clauses allow code to be written to handle particular Exception or Error types. Importantly, catch (Exception e ) {} will catch all exceptions, though it loses the ability to use any added information in extending classes. Errors can be handled similarly, but are generally not handled. A Java Error would be something like a hardware failure that the program probably cannot deal with successfully.If I were redesigning the language I would eliminate the
finally block entirely. The catch blocks should simply branch to the code that follows the last catch block.I would then use only a single
catch block. If needed, the programmer can put a switch inside that block which calls code appropriate to the exception type.That said, let's look at the ways some other languages address the issue.
Error Handling in JavaScript
JavaScript follows Java's
try catch finally lead, with two important differences. First, there is only a single catch block. Second, the thing caught may be anything: object, string, number, ... In JavaScript: The Good Parts, Doug Crockford eliminates the
finally block, leaving exactly what I recommend for Java.Error Handling in Python
Very like Java, but the
catch block is known as an except block.Error Handling in Ruby
Similar to Java, but Ruby stubbornly goes its own way. You don't
try, you begin. You don't catch, you rescue. You don't finally, you ensure.Ruby also features a
retry keyword that repeats execution of the try block."Martin, don't forget that stupid Tim Toady! You can use
catch blocks, too.""Thanks, Monty. I'll put that in."
Monty, my pet python, knows just enough Ruby to criticize it.
Error Handling in C++
Like Java you have
try and catch blocks. Unlike Java there is no finally block. Also unlike Java, there is no restriction on the type of thing caught. Strings and integers, for examples, can be caught. There is also a generic "catch anything" variant, though there is no way to hand the thing caught to the code in this catch block, a disadvantage of strongly-typed languages.

No comments:
Post a Comment