I have 3 Tasks that should run in parallel. I need to await all 3 and then continue processing their results. So something like:
var results = await Task.WhenAll(task1, task2, task3);
return process(results);
This works fine when all 3 tasks complete successfully. However, if one of them fails I get an exception that bubbles up all the way. This is not what I want. If any of these tasks throws an InvalidOperationException
I can continue processing, I just need the process
method to have access to the exception that was thrown.
I realize that I can try...catch
within the tasks but that does not seem like it would be a hack. Beyond being semantically incorrect (the task DID fail - it should not return successfully), if I went with this approach, since the result can be successful OR return an exception, I would have to return a custom type. The Task<T>
object however already exposes an Exception channel so I would prefer to not do double-duty and just use what is already present.