Future<T>.sync 构造函数

Future<T>.sync(
  1. FutureOr<T> computation()
)

返回一个包含立即调用 computation 的结果的 future。

如果调用 computation 抛出异常,则返回的 future 会以错误完成。

如果调用 computation 返回一个 Future<T>,则返回该 future。

如果调用 computation 返回非 future 值,则返回一个已经完成该值的 future。

示例

final result = await Future<int>.sync(() => 12);

实现

factory Future.sync(FutureOr<T> computation()) {
  FutureOr<T> result;
  try {
    result = computation();
  } catch (error, stackTrace) {
    var future = new _Future<T>();
    AsyncError? replacement = Zone.current.errorCallback(error, stackTrace);
    if (replacement != null) {
      future._asyncCompleteError(replacement.error, replacement.stackTrace);
    } else {
      future._asyncCompleteError(error, stackTrace);
    }
    return future;
  }
  return result is Future<T> ? result : _Future<T>.value(result);
}