wait 属性
并行等待 futures。
等待此记录中的所有 futures。如果所有 futures 都成功,则返回值的记录。
返回的 future 在所有 futures 完成时完成。如果有任何 futures 未完成,则返回的 future 也不会完成。
如果有一些 futures 导致错误完成,则返回的 future 将以 ParallelWaitError 完成。The ParallelWaitError.values 是成功的 futures 的值的记录,对于出现错误的 futures 为 null
。The ParallelWaitError.errors 是相同形状的记录,对于成功的 futures 的值为 null
,对于因错误完成的 futures 是一个包含错误的 AsyncError。
实现
Future<(T1, T2, T3, T4, T5, T6, T7)> get wait {
final c = Completer<(T1, T2, T3, T4, T5, T6, T7)>.sync();
final v1 = _FutureResult<T1>($1);
final v2 = _FutureResult<T2>($2);
final v3 = _FutureResult<T3>($3);
final v4 = _FutureResult<T4>($4);
final v5 = _FutureResult<T5>($5);
final v6 = _FutureResult<T6>($6);
final v7 = _FutureResult<T7>($7);
_FutureResult._waitAll([v1, v2, v3, v4, v5, v6, v7], (int errors) {
if (errors == 0) {
c.complete((
v1.value,
v2.value,
v3.value,
v4.value,
v5.value,
v6.value,
v7.value
));
} else {
c.completeError(ParallelWaitError(
(
v1.valueOrNull,
v2.valueOrNull,
v3.valueOrNull,
v4.valueOrNull,
v5.valueOrNull,
v6.valueOrNull,
v7.valueOrNull
),
(
v1.errorOrNull,
v2.errorOrNull,
v3.errorOrNull,
v4.errorOrNull,
v5.errorOrNull,
v6.errorOrNull,
v7.errorOrNull
),
errorCount: errors,
defaultError: v1.errorOrNull ??
v2.errorOrNull ??
v3.errorOrNull ??
v4.errorOrNull ??
v5.errorOrNull ??
v6.errorOrNull ??
v7.errorOrNull
));
}
});
return c.future;
}