多线程-异常处理

任何线程创建范围内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异常

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值