Bad ExceptionHandling
Stumbled upon this today :
Quite useless! Should be :
Why?
data:image/s3,"s3://crabby-images/10de8/10de86a8ea398f12a302c2a297b5e13e60dc6591" alt=""
Quite useless! Should be :
data:image/s3,"s3://crabby-images/526f5/526f5c81f1a74902b0702ec8ef3ad9908629b943" alt=""
Why?
- Exception should be logged. Why else catch exception and do nothing but (re-)throwing exception?!
- Exception must be re-thrown with the throw; statement. Using throw ex; will erase your original stacktrace because a new stacktrace is started at that point. Use throw; to maintain your stacktrace and re-throw the exception! Confusing?! You can check this behavior in IL DASM : difference between throwing and rethrowing statement.
1 Comments:
At 11:04 AM,
Anonymous said…
Hello Pieter
I want to add that in some situations it is okay to throw a new exception instead of rethrowing the exception but there are only 2 reasons why you want to do this:
1) when you want to add more richer information to the exception
2) when you want to throw a more meaningful exception to the caller.
Post a Comment
<< Home