为什么CLR会重新抛出ThreadAbortException

本文关键字:新抛出 ThreadAbortException CLR 为什么 | 更新日期: 2023-09-27 18:15:24

我从《Windows并发编程》一书中得到了以下代码:

void Main()
{
    try
    {
        try
        {
            Console.WriteLine("Inside Main Method");
            Thread.CurrentThread.Abort();
        }
        catch(ThreadAbortException)
        {
            Console.WriteLine("Inside First Catch");
            // Trying to swallow but CLR throws it again....
        }
    }
    catch(ThreadAbortException)
    {
        Console.WriteLine("Inside Second Catch");
        //Thread.ResetAbort();
    }
}

我有兴趣知道为什么CLR重新抛出ThreadAbortException ?它一直这样做,直到我调用"Thread.ResetAbort()"。其次,是否有其他系统定义的异常,得到CLR的特殊处理?

为什么CLR会重新抛出ThreadAbortException

我有兴趣知道为什么CLR重新抛出ThreadAbortException?

因为线程正在中止。人们总是处理所有的异常,即使这样做是危险的。如果一个错误记录例程,比如说,让一个应该被销毁的线程永远活着,那就太奇怪了,不是吗?

是否有其他系统定义的异常,得到CLR的特殊处理?

是的,有几个。例如,栈外异常和内存不足异常也有特殊的行为。

这是一个特殊的例外,http://msdn.microsoft.com/en-us/library/system.threading.threadabortexception.aspx,见备注。从我的理解来看,发生这种情况的原因是。net让您能够在线程关闭之前完成任何清理工作。

有关管道的一些信息请参见此:http://ondotnet.com/pub/a/dotnet/2003/02/18/threadabort.html