Exception handling enables a programmer to cater for exceptional or problematic scenarios by defining a method of overriding the normal program flow during execution. When an exception occurs the normal program flow is interrupted and execution is directed to a piece of code in place to handle the exception which is called the catch statement.
How exceptions effect program flow
An exception is an event that interrupts the program flow of an application.
In the context of a Helium application when an exception occurs the active session will be failed and the transaction will be rolled back.
When an exception is thrown during a scheduled function an entry is written to the __scheduled_function_result__ table.
When an exception is thrown during a web users session an error is written to the Helium Logging Service and an "Exception encountered" error is displayed on the UI.
Execution happens from top to bottom of how the code reads, when an exception happens the transaction is failed, as mentioned above, the only case in which execute may continue is if the exception happens inside a try code block, this phenomenon is called exception handling.
To handle an exception the programmer can use the try statement with a catch block, when an exception is thrown from inside the try block execution is halted in the try and the statements inside the catch block are executed. A finally block can be used after a try-catch to ensure that execution of one more section of code in the scenario that an exception is thrown from the catch block, or there is a missing catch block.
Any type of event happens implicitly inside a transaction in Helium.
Using a try catch block
The following code block shows the syntax of a try catch block, if during execution an exception happens inside the try, we will see the log entries: "inside try statement" then "inside catch statement" then "inside finally statement", this shows the basic program flow.
After the catch keyword to complete the statement there must be a variable name inside parentheses followed by a code block. On the exception that is caught there will always exist 5 values
message (string)
unitName (string)
unitLine (int)
datetimestamp (datetime)
stackTrace (string)
In the following example the try statement is expanded to handle the exception by logging it with Mez:log.
// Example utility method to log the values found on an exception.
void logException(string message, string unitName, int unitLine, datetime datetimestamp, string stackTrace){
Mez:log(String:concat("Exception on {", unitName, ":", unitLine, "} at ", datetimestamp, ": ", message, " || ", stackTrace));
}
void handleException(){
try {
Mez:log("inside try statement");
// throws an exception now ...
} catch (ex){
Mez:log("inside catch statement");
logException(ex.message, ex.unitName, ex.unitLine, ex.datetimestamp, ex.stackTrace);
} finally {
Mez:log("inside finally statement");
}
}
Using the throw statement
The programmer may throw an exception to interrupt the program flow and fail the transaction. This is done using the throw keyword, the throw keyword accepts a single value which will be converted to a string and used as the exception that is thrown within Helium.
void throwStatementExample(){
Mez:log("Throwing an exception now ...");
string error = "Oops, something went wrong!";
throw error;
}
The Null Pointer Exception
Always remember that accessing a member on a null reference causes a null pointer exception, this like other exception can also be handled. Just take care not to swallow exceptions as it may lead to unexpected results.
void throwNPE(){
person obj = null;
obj.firstNames = "null pointer"; // Throws a NullPointerException
}
The programmers nemesis.
The advantages of using exception handling
Allows a separation between error handling code and regular code.
Allows a chance to recover from exceptions that the programmer can foresee.
The disadvantages of using exception handling
There are no real disadvantages of the proper use of exception handling, however take care not to swallow exceptions or the program may yield unexpected results!
Add Comment