App.xaml.cs
3.84 KB
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
77
78
79
80
81
82
83
84
85
using HHECS.Bll;
using HHECS.Model;
using HHECS.Model.Entities;
using HHECS.Model.Enums;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Net.Http;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Threading;
namespace HHECS
{
/// <summary>
/// App.xaml 的交互逻辑
/// </summary>
public partial class App : Application
{
private void Application_Startup(object sender, StartupEventArgs e)
{
//Application.Current.StartupUri = new Uri("Frm_Login.xaml", UriKind.Relative);
//UI线程未捕获异常处理事件(UI主线程)
this.DispatcherUnhandledException += App_DispatcherUnhandledException;
//非UI线程未捕获异常处理事件(例如自己创建的一个子线程)
AppDomain.CurrentDomain.UnhandledException += CurrentDomain_UnhandledException;
//Task线程内未捕获异常处理事件
TaskScheduler.UnobservedTaskException += TaskScheduler_UnobservedTaskException;
}
//UI线程未捕获异常处理事件(UI主线程)
private void App_DispatcherUnhandledException(object sender, DispatcherUnhandledExceptionEventArgs e)
{
Exception ex = e.Exception;
string msg = String.Format("{0}\n\n{1}", ex.Message, ex.StackTrace);//异常信息 和 调用堆栈信息
MessageBox.Show(msg, "UI线程异常");
Logger.Log($"UI线程异常{ex.ToString()}", LogLevel.Exception);
LogExecute.WriteExceptionLog($"UI线程异常{ex.ToString()}", ex);
e.Handled = true;//表示异常已处理,可以继续运行
}
//非UI线程未捕获异常处理事件(例如自己创建的一个子线程)
//如果UI线程异常DispatcherUnhandledException未注册,则如果发生了UI线程未处理异常也会触发此异常事件
//此机制的异常捕获后应用程序会直接终止。没有像DispatcherUnhandledException事件中的Handler=true的处理方式,可以通过比如Dispatcher.Invoke将子线程异常丢在UI主线程异常处理机制中处理
private void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e)
{
if (e.ExceptionObject is Exception ex)
{
string msg = String.Format("发生异常,程序即将停止\n\n{0}\n\n{1}", ex.Message, ex.StackTrace);//异常信息 和 调用堆栈信息
Logger.Log($"非UI线程异常:{ex.ToString()}", LogLevel.Exception);
LogExecute.WriteExceptionLog($"非UI线程异常:{ex.ToString()}", ex);
MessageBox.Show(msg, "非UI线程异常");
}
}
//Task线程内未捕获异常处理事件
private void TaskScheduler_UnobservedTaskException(object sender, UnobservedTaskExceptionEventArgs e)
{
Exception ex = e.Exception;
string msg = String.Format("{0}\n\n{1}", ex.Message, ex.StackTrace);
Logger.Log($"非UI线程异常:{ex.ToString()}", LogLevel.Exception);
LogExecute.WriteExceptionLog($"非UI线程异常:{ex.ToString()}", ex);
//MessageBox.Show(msg, "Task异常");
}
//异常处理 封装
private void OnExceptionHandler(Exception ex)
{
if (ex != null)
{
//string errorMsg = "";
//if (ex.InnerException != null)
//{
// errorMsg += String.Format("【InnerException】{0}\n{1}\n", ex.InnerException.Message, ex.InnerException.StackTrace);
//}
//errorMsg += String.Format("{0}\n{1}", ex.Message, ex.StackTrace);
LogExecute.WriteExceptionLog("Exception", ex);
}
}
}
}