我从“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得到特殊处理?
发布于 2011-11-23 14:41:43
我有兴趣知道为什么
会重新抛出ThreadAbortException?
因为线程正被中止。人们一直在处理所有的异常,即使这样做是危险的。如果一个错误记录例程,比如说,让一个本应永远被销毁的线程保持活动状态,那就很奇怪了,不是吗?
是否有其他系统定义的异常,从CLR得到特殊处理?
是的,有几个。例如,栈外和内存外异常也有特殊的行为。
发布于 2011-11-23 14:09:19
这是一个特殊的例外,http://msdn.microsoft.com/en-us/library/system.threading.threadabortexception.aspx,参见备注。据我所知,发生这种情况的原因是.Net让你有能力在线程关闭之前做任何清理工作。
有关管道的一些信息,请参阅以下内容:http://ondotnet.com/pub/a/dotnet/2003/02/18/threadabort.html
https://stackoverflow.com/questions/8237945
复制相似问题