• .Net下Unhandled Exception的捕获


    C# 处理unhandled Exception方式如下:
    1.    在程序的Main()方法中增加如下代码。
          //处理线程未处理的异常
       Application.ThreadException += new System.Threading.ThreadExceptionEventHandler(Application_ThreadException);
       //处理系统未处理的异常
       AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException);
          //运行程序
       Application.Run(new frmServerMain());
       
    2.    方法:
            static void Application_ThreadException(object sender, System.Threading.ThreadExceptionEventArgs e)
            {
                string str = "";
                Exception error = e.Exception as Exception;
                if (error != null)
                {
                    str = string.Format("Application unhandled exception. ExceptionType:{0} Exception Message: {1} StackTrace:{2} ",
                         error.GetType().Name, error.Message, error.StackTrace);
                }
                else
                {
                    str = string.Format("Application Thread Exception Msg:{0}", e);
                }
                WriteErrInfo(str);
            }

            static void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e)
            {

                string str = "";

                Exception error = e.ExceptionObject as Exception;
                if (error != null)
                {
                    str = string.Format("Application UnhandledException:{0}; StackTrace:{1}", error.Message, error.StackTrace);
                }
                else
                {
                    str = string.Format("Application UnhandledError:{0}", e);
                }
                WriteErrInfo(str);
            }

            static void WriteErrInfo(string vErrMsg)
            {
                using (System.IO.FileStream fs = new System.IO.FileStream(Application.StartupPath + "\Log\TestException.log",
                    System.IO.FileMode.Append, System.IO.FileAccess.Write))
                {
                    using (System.IO.StreamWriter w = new System.IO.StreamWriter(fs,System.Text.Encoding.UTF8))
                    {
                        w.WriteLine(vErrMsg); DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss");
                    }
                }
            }

    详细分析可参见:

    http://www.cnblogs.com/eaglet/archive/2009/02/17/1392191.html


    Impossible = I'm possible
    Don't be the same, be better. Just do it.
    You'll be there.
  • 相关阅读:
    pgloader 学习(七) 从归档文件加载数据
    pgloader 学习(六) 加载csv 数据
    pgloader 学习(五)pgloader 参考手册
    pgloader 学习(四)一些简单操作例子
    pgloader 学习(三)快速使用
    pgloader 学习(二)特性矩阵&&命令行
    pgloader 学习(一)支持的特性
    使用readthedocs 发布 sphinx doc文档
    pgloader 方便的数据迁移工具
    circus && web comsole docker-compose 独立部署web console 的一个bug
  • 原文地址:https://www.cnblogs.com/gavin-king/p/4771748.html
Copyright © 2020-2023  润新知