Usually I put all of my Main method code inside of a try/catch block like so:
public static void Main(string[] args)
{
try
{
// code
}
catch (Exception e)
{
// code
}
}
I do this just in case any exceptions manage to slip out of the rest of the program logic, thus allowing me to do something about it, such as display it to console, log it to a file, etc. However, I have been told that this is bad practice.
Do you think it is bad practice?
That depends on what you do if you catch an error. If you just catch all errors to appear to handle them gracefully - bad practice. I'd say it is bad practice even if you only log there - log locally.
If you really do something to recover the error (e.g. you threw it yourself and know what to do about it) - I'd vote OK :)
Definetly, yes, it is a bad practice, to use Exception class
You should care about types of an exception, not cutting all exceptions on catch block, preventing them to inform system of the error.
Exception class is a base class, and, is a top-level exception can be catched in code. Use the most specific Exceptions in catch block, specifically, the only that, which you code raises in a try {...} catch{...} block, and only if it can be effectively resolved on that particular level (in a function, where try.. catch block is declared)
If you're doing the most intelligent thing you can with the error, it's good practice. That's what try/catch is for.
If you're just throwing the error away (or logging it and throwing it away) — especially if you're doing so regardless of the type of exception — that's considered bad practice.
This might raise the question: what if the most intelligent thing is to log it and throw it away? I want to say that would be an exceptional case. But in practice, my code would assert otherwise. I guess I indulge in a lot of bad practice.
Wrapping any piece of code in a
try
/catch
block without a good reason is bad practice.In the .NET programming model, exceptions should be reserved for truly exceptional cases or conditions. You should only try to catch exceptions that you can actually do something about. Furthermore, you should should hardly ever catch the base
System.Exception
class (but rather prefer to catch the more specific, derived exception classes you can handle). And should a truly unexpected exception be encountered during the course of your program's execution, you actually should crash.Obviously the "correct" answer would have to be made on a case-by-case basis, depending on what's going on inside that
// code
placeholder in yourcatch
block. But if you're asking for a general rule or "best practice", you should always have a specific reason to catch exceptions, not just wrap all of your code in a gianttry
/catch
block as a matter of course without thinking about it.Note that if you're simply trying to catch any unhandled exceptions that might occur for the purposes of logging or error reporting, you should be using the
AppDomain.UnhandledException
event. This is a notification-only event, so it doesn't allow you to handle those exceptions, but it is the right place to implement your logging or error reporting functionality after your application has crashed.EDIT: As I was catching up on my reading of Raymond Chen's excellent blog, "The Old New Thing", I noticed that he had recently published an article on a similar topic. It's specific to COM, rather than the .NET Framework, but the general concepts regarding error handling are equally applicable to both environments. I thought I'd share a couple of gems from the article here, in support of my [apparently quite controversial] opinion.
You can [and should] read the whole article here on his blog: How to turn off the exception handler that COM "helpfully" wraps around your server.
I aggree with 90% of what Cody says. There are some situations similar to the pluggin example where you may want to catch system exceptions. Here is another example consider consuming a WCF web service.
Goal: Consume the service and dispose even if an error is encountered. Allow the error to bubble.
Goal: Consume the service and dispose even if an error is encountered. Prevent the error from bubbling.