程序中使用try catch
对于预知会发生异常的代码段使用try catch主动捕获异常适用于提示给用户或跳转到错误页面或者通过其它方式处理异常(日志通知等)
int i = ;
int j = ;
try
{
LabelText = (i / j)ToString()
}
catch (Exception ex)
{
// 这里处理异常RedirectTransferLogNotice等
ConsoleWriteLine(Page: + exMessage)
}
Global中使用Application_Error
如果异常在程序中没有被处理(如没有try catch)则异常的处理会流转到这个方法这里边可以对异常进行处理但是此方式不能捕捉子线程中的异常
int i = ;
int j = ;
LabelText = (i / j)ToString()
void Application_Error(object sender EventArgs e)
{
// 在出现未处理的错误时运行的代码
ServerTransfer(ErrorPageaspx)
}
string message = HttpContextCurrentError != null ? (HttpContextCurrentErrorInnerException != null ? HttpContextCurrentErrorInnerExceptionMessage : stringEmpty) : stringEmpty;
LabelText = message;
在nfig中配置
出现错误后跳转到ErrorPageaspx和Application_Error类似采用redirectMode模式可以传递异常到错误页面
使用FirstChance异常通知
关联到AppDomain如果应用程序域内发生异常则会首先触发这个事件然后才查找catch块处理异常不过在这个事件中不能处理异常不能消灭异常只是可以按照通知进行处理因为如果这里处理了异常catch块就不能进行处理了
void Application_Start(object sender EventArgs e)
{
// 在应用程序启动时运行的代码
AppDomainCurrentDomainFirstChanceException += new EventHandler<SystemRuntimeExceptionServicesFirstChanceExceptionEventArgs>(CurrentDomain_FirstChanceException)
}
void CurrentDomain_FirstChanceException(object sender SystemRuntimeExceptionServicesFirstChanceExceptionEventArgs e)
{
ConsoleWriteLine(eExceptionMessage)
// 错误响应在上下文中不能使用
// ResponseRedirect(ErrorPageaspx)
// 错误未将对象引用设置到对象的实例
// ServerTransfer(ErrorPageaspx)
}
绑定UnhandledException事件
关联到AppDomain关于这个事件并不是每次都能触发和使用的方式有关情况比较多一般情况下我们只能获取这个异常而不能阻止中断应用程序
下边给出一个例子
void Application_Start(object sender EventArgs e)
{
// 在应用程序启动时运行的代码
AppDomainCurrentDomainUnhandledException += new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException)
}
void CurrentDomain_UnhandledException(object sender UnhandledExceptionEventArgs e)
{
ConsoleWriteLine(eExceptionMessage)
}
一般的未处理异常都会被Application_Error捕捉到我们这里在线程中抛出一个异常
另外StackOverflowException在net中不再能被UnhandledException捕捉到
private void CutString()
{
//throw (new Exception(Test Unhandled exception))
//throw (new StackOverflowException(Test Unhandled exception))
}
protected void Button_Click(object sender EventArgs e)
{
Thread th = new Thread(new ThreadStart(CutString))
thStart()
}
延伸子线程异常的处理网上有介绍通过代理在主线程处理子线程的异常但是在中是无状态的主线程有可能很快消失其中的某些处理可能执行失败
这里使用ThreadSleep使主线程不会很快结束这种异常处理起来很麻烦不建议在中使用处理时间很长的线程
protected void Button_Click(object sender EventArgs e)
{
Thread th = new Thread(new ThreadStart(() =>
{
try
{
throw (new Exception(Test Unhandled exception))
}
catch (Exception ex)
{
//跳转到错误页面
ResponseRedirect(ErrorPageaspx)
}
}))
thStart()
// 主线程会很快结束这里让他等等页面跳转
ThreadSleep()
}
本文列举了处理异常的几种方式有通过订阅AppDomain事件的方式有通过配置文件的方式还有通过Global的方式最后还对子线程异常的处理谈了一点想法但是都没有提供一个完善的解决方案有兴趣的朋友可以自己试试