为什么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的特殊处理?
是的,有几个。例如,栈外异常和内存不足异常也有特殊的行为。
这是一个特殊的例外,http://msdn.microsoft.com/en-us/library/system.threading.threadabortexception.aspx,见备注。从我的理解来看,发生这种情况的原因是。net让您能够在线程关闭之前完成任何清理工作。
有关管道的一些信息请参见此:http://ondotnet.com/pub/a/dotnet/2003/02/18/threadabort.html