Parallel.ForEach方法使用Task Parallel Library来并行执行循环中的操作。当异常发生时,Parallel.ForEach方法会捕获并封装异常,然后将其传递给主线程,而不会中断整个循环。在主线程中,您可以通过调用ParallelLoopResult对象的异常属性来检查是否有任何异常发生。您可以使用try-catch块来处理这些异常,如下所示:
try
{
Parallel.ForEach(collection, item =>
{
// Your code here
});
}
catch (AggregateException ex)
{
foreach (var innerException in ex.InnerExceptions)
{
// Handle each individual exception
}
}
在上面的代码中,异常将被捕获并封装为AggregateException对象。然后,您可以通过遍历InnerExceptions属性来处理每个异常。请注意,可能会有多个异常发生,因此需要遍历InnerExceptions属性来处理它们。
另外,您还可以通过设置ParallelOptions对象的MaxDegreeOfParallelism属性来控制并行执行的最大线程数,并通过设置CancellationToken对象来取消并行操作。这样您可以更好地控制并行执行过程中的异常处理和线程管理。