我有以下例外
System.Threading.ThreadAbortException:线程被中止。在System.Net.UnsafeNclNativeMethods.OSSOCK.recv(IntPtr socketHandle,Byte* pinnedBuffer,Int32 len,SocketFlags socketFlags)
这是当代码试图发送电子邮件时。
我最大的问题是,当这种情况发生时,它会阻止我的所有其他代码运行(这是一个asp.net站点),即使我正在尝试捕获并处理异常。
代码执行一个foreach循环并运行良好,直到这个异常被击中,这时我在循环中捕获异常。然后,循环退出,foreach中的其他项中的非项被循环通过。
if (entry.VatInvoiceRequested)
{
try
{
using (var email = new EntryVatReceiptEmail(entry.Id))
{
if (email.NeedReceipt)
{
email.SendEmail();
email.SendEntryChargeMail();
}
}
}
catch (Exception ex)
{
Logger.Log4NetLogger.Error("Error sending VAT invoice", ex);
}
log.Debug("Entry Handler - About to return from Process()");
}现在,我希望调用最后一个日志行,但当异常被捕获时不会调用它。为了澄清,捕获中的日志正在工作,并被记录到日志中。
发布于 2018-03-02 12:08:00
每次捕获后都会自动重新抛出ThreadAbortException,只能在catch块中执行Thread.ResetAbort()。但是不要这样做,如果您的线程被中止,您需要找到确切的原因。
https://stackoverflow.com/questions/49068717
复制相似问题