Is it a GOTO statement?
Or PUBLIC STATIC FINAL STRING False = Boolean.True; ?
No, I'm quite convinced that a developer's greatest shame is an end-user seeing an exception screen.
Any kind of exception: Object Reference Not Set To An Instance Of An Object, 404: Not Found, PC LOAD LETTER.
Honestly, no client should ever see "Object Reference Not Set To An Instance Of An Object". They should see a nice message saying "the <blah> setting has not been set, please have your administrator configure this setting".
Zero code should exist outside of a try-catch block!
An end-user seeing an exception page should be the greatest shame a developer can have. Developer mind you... mere coders don't care, they're paid to make it work, not to make it work right. "Talk to me about exception handling" should be a required line in every developer interview."Yeah, but all those try-catch add so much extra code to your product!"
Yes, 7 lines minimum:
try
{
//<your existing code>
}
catch (ExceptionType ex)
{
throw ex;
}
And if I ever see an empty Catch, I want to punch someone! It would do nothing: you're catching the exception and doing nothing with it. No log, no throw, no goto, no nothing. At the least, log it internally so the dev can see what's happening when he debugs, without having to manually step through every line. Preferably, put intelligence in there so it can tell the user what happened and why it didn't do what they were expecting it to do:{
//<your existing code>
}
catch (ExceptionType ex)
{
throw ex;
}
- "Cannot access the database"
- "'asdf' is not a valid date"
- "I cannot divide by zero"
- "Chuck Norris exception, recovering from roundhouse kick, please wait..."
Just something useful! Even something funny... (or customizable).
Don't put one gigantic try-catch around the entire 50-line method call
Break it up so that the exceptions are useful to the developer. Try-catch an action: instantiate something, assign it a value, access a property of it. Wrap that before you move on:
object variable = null;
variable = factory.getNewObject(context,settings);
int result = variable.IntValue;
Wrap that in a try catch!!!variable = factory.getNewObject(context,settings);
int result = variable.IntValue;
- factory can throw errors
- variable.IntValue might throw an ObjRef error
There's two right there, catch those before moving on.