C# 应用程序,运行时异常信息捕获

示例:

static class Program
{
    /// <summary>
    /// 应用程序的主入口点。
    /// </summary>
    [STAThread]
    static void Main()
    {
        ApplicationException.Run(call);     // 调用异常信息捕获类,进行异常信息的捕获
    }

    // 应用程序,入口逻辑
    public static void call()
    {
        Application.EnableVisualStyles();
        Application.SetCompatibleTextRenderingDefault(false);

        if (Update.Updated())
        {
            DependentFiles.checksAll();     // 检测工具运行依赖文件
            ToolSetting.Instance();         // 载入工具的配置信息
                
            Application.Run(new Form4());
        }
    }

}
/// <summary>
/// 此类用于捕获Application异常信息
/// </summary>
class ApplicationException
{
    /// <summary>
    /// 定义委托接口处理函数,调用此类中的Main函数为应用添加异常信息捕获
    /// </summary>
    public delegate void ExceptionCall();

    public static void Run(ExceptionCall exCall)
    {
        try
        {
            //设置应用程序处理异常方式:ThreadException处理
            Application.SetUnhandledExceptionMode(UnhandledExceptionMode.CatchException);
            //处理UI线程异常
            Application.ThreadException += new System.Threading.ThreadExceptionEventHandler(Application_ThreadException);
            //处理非UI线程异常
            AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException);

            if (exCall != null) exCall();
        }
        catch (Exception ex)
        {
            string str = GetExceptionMsg(ex, string.Empty);
            MessageBox.Show(str, "系统错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
        }
    }

    ///--------------------------------------------------------------------------

    / <summary>
    / 应用程序的主入口点。
    / </summary>
    //[STAThread]
    //static void Main()
    //{
    //    try
    //    {
    //        //设置应用程序处理异常方式:ThreadException处理
    //        Application.SetUnhandledExceptionMode(UnhandledExceptionMode.CatchException);
    //        //处理UI线程异常
    //        Application.ThreadException += new System.Threading.ThreadExceptionEventHandler(Application_ThreadException);
    //        //处理非UI线程异常
    //        AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException);

    //        #region 应用程序的主入口点
    //        Application.EnableVisualStyles();
    //        Application.SetCompatibleTextRenderingDefault(false);
    //        Application.Run(new Form1());
    //        #endregion
    //    }
    //    catch (Exception ex)
    //    {
    //        string str = GetExceptionMsg(ex, string.Empty);
    //        MessageBox.Show(str, "系统错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
    //    }
    //}


    static void Application_ThreadException(object sender, System.Threading.ThreadExceptionEventArgs e)
    {
        string str = GetExceptionMsg(e.Exception, e.ToString());
        MessageBox.Show(str, "系统错误", MessageBoxButtons.OK, MessageBoxIcon.Error);

        //bool ok = (MessageBox.Show(str, "系统错误,提交bug信息?", MessageBoxButtons.OKCancel, MessageBoxIcon.Error) == DialogResult.OK);
        //if (ok) sendBugToAuthor(str);

        Update.Updated();      // 捕获运行异常后,检测是否有版本更新
        //LogManager.WriteLog(str);
    }

    static void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e)
    {
        string str = GetExceptionMsg(e.ExceptionObject as Exception, e.ToString());
        MessageBox.Show(str, "系统错误", MessageBoxButtons.OK, MessageBoxIcon.Error);

        //bool ok = (MessageBox.Show(str, "系统错误,提交bug信息?", MessageBoxButtons.OKCancel, MessageBoxIcon.Error) == DialogResult.OK);
        //if (ok) sendBugToAuthor(str);

        Update.Updated();      // 捕获运行异常后,检测是否有版本更新
        //LogManager.WriteLog(str);
    }

    /// <summary>
    /// 生成自定义异常消息
    /// </summary>
    /// <param name="ex">异常对象</param>
    /// <param name="backStr">备用异常消息:当ex为null时有效</param>
    /// <returns>异常字符串文本</returns>
    static string GetExceptionMsg(Exception ex, string backStr)
    {
        StringBuilder sb = new StringBuilder();
        sb.AppendLine("****************************异常文本****************************");
        sb.AppendLine("【出现时间】:" + DateTime.Now.ToString("yyyy-MM-dd hh:mm:ss"));
        if (ex != null)
        {
            sb.AppendLine("【异常类型】:" + ex.GetType().Name);
            sb.AppendLine("【异常信息】:" + ex.Message);
            sb.AppendLine("【堆栈调用】:" + ex.StackTrace);
            sb.AppendLine("【异常方法】:" + ex.TargetSite);
        }
        else
        {
            sb.AppendLine("【未处理异常】:" + backStr);
        }
        sb.AppendLine("***************************************************************");


        Update.Updated();      // 捕获运行异常后,检测是否有版本更新

        return sb.ToString();
    }
}

Update.Updated();  // 为我自己程序里的更新逻辑,请删除。




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值