中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C#程序異常關閉時的捕獲

發布時間:2020-10-11 11:20:38 來源:腳本之家 閱讀:133 作者:Alan.hsiang 欄目:編程語言

本文主要以一個簡單的小例子,描述C# Winform程序異常關閉時,如何進行捕獲,并記錄日志。

概述

有時在界面的事件中,明明有try... catch 進行捕獲異常,但是還是會有異常關閉的情況,所以在程序中如何最終的記錄一些無法捕獲的異常,會大大方便問題的定位分析及程序優化。

涉及知識點

以下兩個異常事件,主要應用不同的場景。

  • Application.ThreadException 在發生應用程序UI主線程中未捕獲線程異常時發生,觸發的事件。
  • AppDomain.CurrentDomain.UnhandledException 當后臺線程中某個異常未被捕獲時觸發。

源代碼

主要程序(Program):

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace DemoException
{
  static class Program
  {
    /// <summary>
    /// 應用程序的主入口點。
    /// </summary>
    [STAThread]
    static void Main()
    {
      Application.SetUnhandledExceptionMode(UnhandledExceptionMode.CatchException);
      //處理UI線程異常
      Application.ThreadException += new System.Threading.ThreadExceptionEventHandler(Application_ThreadException);
      //處理非線程異常
      AppDomain.CurrentDomain.UnhandledException +=new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException) ;
      Application.EnableVisualStyles();
      Application.SetCompatibleTextRenderingDefault(false);
      Application.Run(new FrmMain());
      glExitApp = true;//標志應用程序可以退出
    }

    /// <summary>
    /// 是否退出應用程序
    /// </summary>
    static bool glExitApp = false;

    /// <summary>
    /// 處理未捕獲異常
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    private static void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e)
    {

      SaveLog("-----------------------begin--------------------------");
      SaveLog("CurrentDomain_UnhandledException"+DateTime.Now.ToString("yyyy-MM-dd hh:mm:ss"));
      SaveLog("IsTerminating : " + e.IsTerminating.ToString());
      SaveLog(e.ExceptionObject.ToString());
      SaveLog("-----------------------end----------------------------");
      while (true)
      {//循環處理,否則應用程序將會退出
        if (glExitApp)
        {//標志應用程序可以退出,否則程序退出后,進程仍然在運行
          SaveLog("ExitApp");
          return;
        }
        System.Threading.Thread.Sleep(2 * 1000);
      };
    }

    /// <summary>
    /// 處理UI主線程異常
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    private static void Application_ThreadException(object sender, System.Threading.ThreadExceptionEventArgs e)
    {
      SaveLog("-----------------------begin--------------------------");
      SaveLog("Application_ThreadException:" + e.Exception.Message);
      SaveLog(e.Exception.StackTrace);
      SaveLog("-----------------------end----------------------------");
    }

    public static void SaveLog(string log)
    {
      string filePath =AppDomain.CurrentDomain.BaseDirectory+ @"\objPerson.txt";
      //采用using關鍵字,會自動釋放
      using (FileStream fs = new FileStream(filePath, FileMode.Append))
      {
        using (StreamWriter sw = new StreamWriter(fs, Encoding.Default))
        {
          sw.WriteLine(log);
        }
      }
    }
  }
}

出錯的程序:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace DemoException
{
  public partial class FrmMain : Form
  {

    public FrmMain()
    {
      InitializeComponent();
    }

    private void FrmMain_Load(object sender, EventArgs e)
    {
      
    }

    private void btnTestUI_Click(object sender, EventArgs e)
    {
      int a = 0;
      int c = 10 / a;
    }

    private void btnTest2_Click(object sender, EventArgs e)
    {
      Thread t = new Thread(new ThreadStart(() =>
      {
        int a = 0;
        int c = 10 / a;
      }));
      t.IsBackground = true;
      t.Start();
    }
  }
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

重庆市| 射洪县| 锡林郭勒盟| 都匀市| 宁化县| 堆龙德庆县| 鹤山市| 西藏| 沂源县| 习水县| 天镇县| 湖州市| 夹江县| 玉溪市| 海原县| 固阳县| 沈阳市| 泰兴市| 鄂伦春自治旗| 三亚市| 邢台市| 深泽县| 婺源县| 辽宁省| 仁怀市| 邹平县| 大厂| 惠来县| 安平县| 武城县| 大安市| 永登县| 织金县| 库伦旗| 叙永县| 肇州县| 嘉禾县| 崇信县| 兴隆县| 龙游县| 江永县|