Future execution leads to unhandled exception

Dmi*_*pka 3 future unhandled-exception dart

import 'dart:async';

void main() {
  divide(1, 0).then((result) => print('1 / 0 = $result'))
    .catchError((error) => print('Error occured during division: $error'));
}

Future<double> divide(int a, b) {
  if (b == 0) {
    throw new Exception('Division by zero');
  }
  return new Future.value(a/b);
}
Run Code Online (Sandbox Code Playgroud)

目前我正在学习如何在 Dart 中使用 future,并且我陷入了这样一个简单的例子中。当用户尝试执行除以零时,我的未来会抛出异常。但是, .catchError 不处理我的异常。我得到了未处理的异常,并带有堆栈跟踪。我很确定我错过了一些明显的东西,但无法理解到底是什么。

据我了解,还有另一种方法来处理错误:

divide(1, 0).then((result) => print('1 / 0 = $result'),
    onError: (error) => print('Error occured during division: $error'));
Run Code Online (Sandbox Code Playgroud)

使用命名可选参数 - onError。这样做仍然会导致未处理的异常。

我还想澄清一件事。我对吗?- 这两种方法之间的唯一区别是 .catchError() 还处理内部 future 抛出的错误(在外部 future 的 then() 方法内部调用的 future),而 onError 只捕获外部 future 抛出的错误?

德米特里

谢谢。

Gün*_*uer 5

您的错误处理不起作用,因为错误是在代码的同步部分引发的。仅仅因为该方法返回 future 并不意味着该方法中的所有内容都是异步的。

void main() {
  try {
    divide(1, 0)
        .then((result) => print('1 / 0 = $result'));
  } catch (error) {
    print('Error occured during division: $error');
  }
}
Run Code Online (Sandbox Code Playgroud)

如果你divide像这样改变你的功能

Future<double> divide(int a, b) {
  return new Future(() {
    if (b == 0) {
      throw new Exception('Division by zero');
    }
    return new Future.value(a / b);
  });
}
Run Code Online (Sandbox Code Playgroud)

您收到异步错误并且异步错误处理有效。

一种更简单的方法是使用新的 async/await

main() async {
  try {
    await divide(1, 0);
  } catch(error){
    print('Error occured during division: $error');
  }
}
Run Code Online (Sandbox Code Playgroud)

尝试DartPad

另一个优点是这在两种情况下都有效。

  • 是的,在这种情况下 `new Future.value()` 是不必要的。 (2认同)