1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 | using System; using System.Configuration; using System.Text; using System.Windows.Forms; using ZB.QueueSys.Common; namespace ZB.QueueSys { static class Program { /// <summary> /// 应用程序的主入口点。 /// </summary> [STAThread] static void Main() { Application.SetUnhandledExceptionMode(UnhandledExceptionMode.CatchException); //处理UI线程异常 Application.ThreadException += new System.Threading.ThreadExceptionEventHandler(Application_ThreadException); //处理非UI线程异常 AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException); Application.EnableVisualStyles(); Application.SetCompatibleTextRenderingDefault( false ); //数据库类型 DBHelper.Instance.DBType = int .Parse(ConfigurationManager.AppSettings[ "DBType" ]); //数据库连接串 DBHelper.Instance.ConnectionStr = ConfigurationManager.ConnectionStrings[ "DBStr" ].ConnectionString; Application.Run( new MainForm()); //Application.Run(new QueueForm()); } private static void CurrentDomain_UnhandledException( object sender, UnhandledExceptionEventArgs e) { string str = GetExceptionMsg(e.ExceptionObject as Exception, e.ToString()); LogHelper.Instance.SaveText(str); Exception error = e.ExceptionObject as Exception; MessageBox.Show(error.Message, "系统异常提示信息" , MessageBoxButtons.OK, MessageBoxIcon.Error); } private static void Application_ThreadException( object sender, System.Threading.ThreadExceptionEventArgs e) { string str = GetExceptionMsg(e.Exception, e.ToString()); LogHelper.Instance.SaveText(str); MessageBox.Show(e.Exception.Message, "系统异常提示信息" , MessageBoxButtons.OK, MessageBoxIcon.Error); } /// <summary> /// 生成自定义异常消息 /// </summary> /// <param name="ex">异常对象</param> /// <param name="backStr">备用异常消息:当ex为null时有效</param> /// <returns>异常字符串文本</returns> private 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( "***************************************************************" ); return sb.ToString(); } } } |
博客内容主要用于日常学习记录,内容比较随意,如有问题,还需谅解!!!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本