Is prevTask.Wait() recommended to be used with ContinueWith (from the Tasks library)?
Solution 1:
Ehhh.... I think some of the current answers are missing something: what happens with exceptions?
The only reason you would call Wait
in a continuation would be to observe a potential exception from the antecedent in the continuation itself. The same observation would happen if you accessed Result
in the case of a Task<T>
and also if you manually accessed the Exception
property.
Frankly, I wouldn't call Wait
or access Result
because if there is an exception you'll pay the price of re-raising it which is unnecessary overhead. Instead you can just check the IsFaulted
property off the antecedent Task
. Alternatively you can create forked workflows by chaining on multiple sibling continuations that only fire based on either success or failure with TaskContinuationOptions.OnlyOnRanToCompletion
and TaskContinuationOptions.OnlyOnFaulted
.
Now, it's not necessary to observe the exception of the antecedent in the continuation, but you may not want your workflow to move forward if, say, "Step 1" failed. In that case: specifying TaskContinuationOptions.NotOnFaulted
to your ContinueWith
calls would prevent the continuation logic from ever even firing.
Keep in mind that, if your own continuations don't observe the exception, the person who is waiting on this overall workflow to complete is going to be the one to observe it. Either they're Wait
ing on the Task
upstream or have tacked on their own continuation to know when it is complete. If it is the latter, their continuation would need to use the aforementioned observation logic.
Solution 2:
You are using it correctly.
Creates a continuation that executes asynchronously when the target Task completes.
Source: Task.ContinueWith Method (Action as MSDN)
Having to call prevTask.Wait()
in every Task.ContinueWith
invocation seems like a weird way to repeat unnecessary logic - i.e. doing something to be "super duper sure" because you actually don't understand what a certain bit of code does. Like checking for a null just to throw an ArgumentNullException
where it would've been thrown anyway.
So, no, whoever told you that is wrong and probably doesn't understand why Task.ContinueWith
exists.