本文參考網上搜索的信息,並作了適當修改可讓捕捉到異常以後阻止程序退出。html
另給出了經過命令行自動重啓的方法。spring
若是一個線程裏運行下面的代碼app
int a = 0; int c = 10 / a;
將會致使程序自動結束,並且沒有任何提示信息 可是若是是在主線程裏運行這個代碼,是會彈出異常信息對話框的post
請問如何在線程裏也出現這個異常信息對話框.或者
避免程序直接退出,忽略異常,繼續往下執行呢?
在WINFORM主線程捕獲所有異常就行,以下代碼:
//處理未捕獲的異常 Application.SetUnhandledExceptionMode(UnhandledExceptionMode.CatchException); //處理UI線程異常 Application.ThreadException += new System.Threading.ThreadExceptionEventHandler(Application_ThreadException); //處理非UI線程異常 AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException);
最常出現的錯誤在 :UnhandledException 裏出現。詳細代碼以下:
/// <summary> /// 應用程序的主入口點。 /// </summary> [STAThread] static void Main(string[] args) { Application.EnableVisualStyles(); Application.SetCompatibleTextRenderingDefault(false); //處理未捕獲的異常 Application.SetUnhandledExceptionMode(UnhandledExceptionMode.CatchException); //處理UI線程異常 Application.ThreadException += new System.Threading.ThreadExceptionEventHandler(Application_ThreadException); //處理非UI線程異常 AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException); Application.Run(new Form1(args)); glExitApp = true;//標誌應用程序能夠退出 } /// <summary> /// 是否退出應用程序 /// </summary> static bool glExitApp = false; static void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e) { LogHelper.Save("CurrentDomain_UnhandledException", LogType.Error); LogHelper.Save("IsTerminating : " + e.IsTerminating.ToString(), LogType.Error); LogHelper.Save(e.ExceptionObject.ToString()); while (true) {//循環處理,不然應用程序將會退出 if (glExitApp) {//標誌應用程序能夠退出,不然程序退出後,進程仍然在運行 LogHelper.Save("ExitApp"); return; } System.Threading.Thread.Sleep(2*1000); }; } static void Application_ThreadException(object sender, System.Threading.ThreadExceptionEventArgs e) { LogHelper.Save("Application_ThreadException:" + e.Exception.Message, LogType.Error); LogHelper.Save(e.Exception); //throw new NotImplementedException(); }
若是程序須要重啓只須要在捕獲的事件處理時啓動當前應用程序的代碼便可。參考以下:this
CmdStartCTIProc(Application.ExecutablePath, "cmd params");//放到捕獲事件的處理代碼後,重啓程序,須要時加上重啓的參數 /// <summary> /// 在命令行窗口中執行 /// </summary> /// <param name="sExePath"></param> /// <param name="sArguments"></param> static void CmdStartCTIProc(string sExePath, string sArguments) { Process p = new Process(); p.StartInfo.FileName = "cmd.exe"; p.StartInfo.UseShellExecute = false; p.StartInfo.RedirectStandardInput = true; p.StartInfo.RedirectStandardOutput = true; p.StartInfo.RedirectStandardError = true; p.StartInfo.CreateNoWindow = false; p.StartInfo.WindowStyle = System.Diagnostics.ProcessWindowStyle.Hidden; p.Start(); p.StandardInput.WriteLine(sExePath + " " + sArguments); p.StandardInput.WriteLine("exit"); p.Close(); System.Threading.Thread.Sleep(2000);//必須等待,不然重啓的程序還未啓動完成;根據狀況調整等待時間 }
另一種重啓進程的方式:spa
//重啓程序,須要時加上重啓的參數 System.Diagnostics.ProcessStartInfo cp = new System.Diagnostics.ProcessStartInfo(); cp.FileName = Application.ExecutablePath; cp.Arguments = "cmd params"; cp.UseShellExecute = true; System.Diagnostics.Process.Start(cp);
看了以爲有用的朋友,若是您方便的話,能夠頂一下。謝謝!命令行
程序崩潰後重啓,能夠試試下面的方式:線程
/// <summary> /// 應用程序的主入口點。 /// </summary> [STAThread] static void Main() { Application.ThreadException+=new System.Threading.ThreadExceptionEventHandler(Application_ThreadException); Application.EnableVisualStyles(); Application.SetCompatibleTextRenderingDefault(false); Application.Run(new Form1()); } private static void Application_ThreadException(object sender, System.Threading.ThreadExceptionEventArgs e) { Application.Restart(); }