任何线程创建范围内try/catch/finally块,当线程开始执行便不再与其有任何关系。如下代码:
static void Main(string[] args) { try { new Thread(TProc).Start(); } catch (Exception ex) { //不会捕获到异常 Console.WriteLine(ex.Message); } } static void TProc() { //抛出一个NullReferenceException异常 throw null; }
注意,用于全局异常处理的Application.ThreadException事件也不能捕获到这个异常,NET framework为全局异常处理提供了一个更低级别的事件:AppDomain.UnhandledException,这个事件在任何类型的程序(有或没有用户界面)的任何线程有任何未处理的异常触发。
另一个比较特别的是Thread.Abort()方法,Abort()方法可以用来销毁线程,Abort()方法的调用会在线程内部触发ThreadAbortException异常,如果没有在线程的代码中捕获改异常,线程就会中止。
ThreadAbortException是一个特殊的异常,与其它异常一样,这个异常也可以捕获,但是,一旦catch代码块执行完毕,就会再次自动引发该异常,此时,运行库就会执行finally代码块,之后销毁线程。
static void Main() { Thread t = new Thread(TProc); t.Start(); while (!t.IsAlive) ; try { t.Abort(); } catch (ThreadAbortException ex) { Console.WriteLine("这一句更不可能被执行"); Console.ReadLine(); } } static void TProc() { try { for (int i = 0; i < 10; i++) Thread.Sleep(100); } catch (ThreadAbortException ex) { Console.WriteLine(ex.Message); Console.ReadLine(); } Console.WriteLine("这一句不会被执行"); Console.ReadLine(); }
同时需要注意的是,在多线程环境下线程方法中编写一般的异常处理代码之前,应慎重考虑一下,因为catch(Exception ex)也会捕获ThreadAbortException异常