Auto-restarting Forms Applications

  • Thread starter Thread starter TJO
  • Start date Start date
T

TJO

I am trying to understand how to restart a windows form application in
the event of an unexpected exception on the main form. I want to have
the program attempt to restart the application 3 times then fail
gracefully. The problem I am experiencing is this seems to work fine
for the first 2 attempts but the third time the program abruptly stops
at the point of the Exception and never gets to the handler on the
Program. Please advise, thank you.

static class Program
{
static int restartCount = 3;

/// <summary>
/// The main entry point for the application.
/// </summary>
///[STAThread]
static void Main()
{
Application.EnableVisualStyles();
Application.SetCompatibleTextRenderingDefault( false );
Application.ThreadException += new
System.Threading.ThreadExceptionEventHandler(
Application_ThreadException );

AppDomain.CurrentDomain.UnhandledException += new
UnhandledExceptionEventHandler( CurrentDomain_UnhandledException );
Application.SetUnhandledExceptionMode(
UnhandledExceptionMode.CatchException);

restart();

//Application.Run( new Form1() );
Application.Run();

Console.WriteLine( "Program.Main() error handler" );

}

static void Application_ThreadException( object sender,
System.Threading.ThreadExceptionEventArgs e )
{
Console.WriteLine( "ThreadException Handled" );
restart();
}

static void CurrentDomain_UnhandledException( object sender ,
UnhandledExceptionEventArgs e )
{
Console.WriteLine( "UnhandledException Handled" );
restart();
}

static void restart()
{
restartCount--;

if(restartCount < 0)
Environment.Exit( 0 );

if (restartCount > -1)
{
Console.WriteLine( "Attempting Restart #{0}" , 3 - restartCount );

Form1 form = new Form1();
form.ShowDialog();

}
}
}

public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
myFuction();
}

private void myFuction()
{
object o = null;

// This will throw exception
Console.WriteLine( ((Control) o).ToString() );
}
}
 
I had the same problem and I finally found the Application.Restart( )
method. If you find an other method, please let me know

Aristotelis
 
I am trying to understand how to restart a windows form application in
the event of an unexpected exception on the main form. I want to have
the program attempt to restart the application 3 times then fail
gracefully. The problem I am experiencing is this seems to work fine
for the first 2 attempts but the third time the program abruptly stops
at the point of the Exception and never gets to the handler on the
Program. Please advise, thank you.

I can't give you a definite answer as to why it works 2 times and fails the
3rd time but this behaviour doesn't surprises me. In your unhandeld
exception handler, you are calling restart() which itslef throws an
exception. If exceptions throws in an unhandled exception handler caused
your unhandled exception handler to be called then you could very easily
end up in an infinite loop (and since unhandled exceptions usually happen
when something goes really wrong, such as the state of your application
being corrupted beyond repair the system having run out of memory, it is
common that code in the unhandled exception handler fails too). So the CLR
must take steps to avoid that.

In addition, if your application threw an unhandled exception, simply
recreating the main form and re-showing it would probably not be a great
solution anyway. In your basic app, you only have an empty main form so
that's ok but in a real world application, you would have hundredrs or
thousands of objects and static data loaded in memory, ressources hold and
so on. Recreating the main form would only add to the confusion and
probably cause even more errors. When something goes really wrong, you
should shut down the process to allow for memory and other resources to be
released and then restart the whole process. You can use Process.Start()
and Application.StartupPath to restart your application. If you want to
monitor the number of times that you have restarted your application, you
could write this information in the registry or in a file in the
application's IsolatedStorage.
 
I have used this but the underlying inability to properly shutdown and
restart remains. The error on subsequent attempts after the first few
is not handled.

Pitaridis said:
I had the same problem and I finally found the Application.Restart( )
method. If you find an other method, please let me know

Aristotelis

? "TJO said:
I am trying to understand how to restart a windows form application in
the event of an unexpected exception on the main form. I want to have
the program attempt to restart the application 3 times then fail
gracefully. The problem I am experiencing is this seems to work fine
for the first 2 attempts but the third time the program abruptly stops
at the point of the Exception and never gets to the handler on the
Program. Please advise, thank you.

static class Program
{
static int restartCount = 3;

/// <summary>
/// The main entry point for the application.
/// </summary>
///[STAThread]
static void Main()
{
Application.EnableVisualStyles();
Application.SetCompatibleTextRenderingDefault( false );
Application.ThreadException += new
System.Threading.ThreadExceptionEventHandler(
Application_ThreadException );

AppDomain.CurrentDomain.UnhandledException += new
UnhandledExceptionEventHandler( CurrentDomain_UnhandledException );
Application.SetUnhandledExceptionMode(
UnhandledExceptionMode.CatchException);

restart();

//Application.Run( new Form1() );
Application.Run();

Console.WriteLine( "Program.Main() error handler" );

}

static void Application_ThreadException( object sender,
System.Threading.ThreadExceptionEventArgs e )
{
Console.WriteLine( "ThreadException Handled" );
restart();
}

static void CurrentDomain_UnhandledException( object sender ,
UnhandledExceptionEventArgs e )
{
Console.WriteLine( "UnhandledException Handled" );
restart();
}

static void restart()
{
restartCount--;

if(restartCount < 0)
Environment.Exit( 0 );

if (restartCount > -1)
{
Console.WriteLine( "Attempting Restart #{0}" , 3 - restartCount );

Form1 form = new Form1();
form.ShowDialog();

}
}
}

public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
myFuction();
}

private void myFuction()
{
object o = null;

// This will throw exception
Console.WriteLine( ((Control) o).ToString() );
}
}
 
I realize that shutting down is the best thing to do. My goal here is
to try go have the application restart itself until the administrator
can reboot it and thereby try to keep things as seemless as possible.

My actual production application will send text message alerts to the
administrator so that he will know the program crashed. He will also
be notified when the maximum number of attempted restarts has been
reached.

You have gottem me to think that throwing exceptions within exceptions
may be the issue. I will continue researching.

If anyone else cares to assist. The program sample I provided in my
first post does illustrate to problem so you can run it too.

Thanks for everyone input.
 
I realize that shutting down is the best thing to do. My goal here is
to try go have the application restart itself until the administrator
can reboot it and thereby try to keep things as seemless as possible.

My actual production application will send text message alerts to the
administrator so that he will know the program crashed. He will also
be notified when the maximum number of attempted restarts has been
reached.

You have gottem me to think that throwing exceptions within exceptions
may be the issue. I will continue researching.

If anyone else cares to assist. The program sample I provided in my
first post does illustrate to problem so you can run it too.

Thanks for everyone input.

An alternative solution could be to have a monitor app that detects when
the program is not running and reloads it, as if it completely crashes
out with some form of thread death there is no guarantee that it will
ever run an exception handler or finally block.
 
If this app needs to be running all the time, you should look into rewriting
it as a service. Or using a service to perform the operations that must be
running all the time. Run your code on a worker thread and handle thread
aborts by attempting to restart the thread. You should do some reading on
multithreading, as it is much easier to gracefully recover from a thread
crashing than your entire program crashing.
 
Back
Top