Code in Program.cs
[STAThread]
static void Main()
{
Application.EnableVisualStyles();
Application.SetCompatibleTextRenderingDefault(false);
try
{
Application.Run(new Form1());
}
catch (Exception ex)
{
MessageBox.Show("Blah...");
}
}
In Form1 I have a button with the code throw new Exception("");.
If I run the application from Visual Studio, then my messagebox pops up (with message ‘Blah…’). But if I run the application from executable file, then the catch block doesn’t execute at all.
Why the difference?
I am using Visual Studio 2010, .NET 4.0, Windows XP.
This is because the standard exception handling for a Windows Forms application behaves differently when the Visual Studio debugger is attached – normally the exception handler built into the
Application.Runmethod catches unhandled exceptions so that it can do things like show the following dialog:If it allowed the exception to be thrown outside of the
Application.Runmethod then it would prevent the application from continuing if the user presses “continue” (as the catch is outside of the message pump).When debugging however this is disabled, presumably so that the debugger will jump straight into debugging mode on an unhandled exception rather than the above dialog being shown.
If you wish to handle unhandled exceptions in your Windows Forms application then you should handle the
Application.ThreadExceptionEvent. Alternatively you can alter this behaviour with theApplication.SetUnhandledExceptionModeMethod.You are by no means alone in being confused by this: