Dart中的Future及其then、catchError方法
在学习Flutter的过程中,看到网上很多人使用Future的时候会使用到future.then()这种操作,一直有些困惑,从而自己在写Flutter的过程中都是尽可能的避免使用到then,但是感觉不能够继续躲避了,决定学习一波。
官方对于Future的描述是:一个潜藏的value或者error,在未来的某一刻是可用的。
之前的文章中讲到Future及其搭档await和async的搭配使用实现等待耗时操作,那么这里的then回调就是回归Future的本意:在未来的某一时刻可用
then回调
Future<R> then <R>(
FutureOr<R> onValue(
T value
), {
Function onError
})
可见then的参数有两个,第一个是一个Callback,第二个是一个可选的命名Function参数onError。
- Callback:上面说到Future是一个潜藏的value或者error,当Future成功完成的时候则会执行onValue这个Callback
- Function onError:而这个函数的执行条件就是Future失败的时候
补充:then方法的返回类型还是一个Future(称他为f2,调用then的为f1),这个返回的f2的value或者error在最初的时候与f1的相同;但是Callback的作用就是处理f1中的value,而onError的作用就是处理f1中的error;所以如果Callback或者onError也是返回了一个Future f3,那么then方法返回的f2将会被f3所覆盖
onError这个Function的参数也是两个:第一个是Exception,第二个是可选参数StackTrace。
catchError
catchError方法和then方法是同一级别的,catchError是最后的保障,catchError与then方法的onError参数不同的是,catchError可以处理之前所有处理过程中产生的error,而onError只能够处理调用then的Future对象的异常
future1.then((value)=>useValue(value), onError: (e){}).then().catchError();
上面的onError只能够处理future1过程中产生的异常,而catchError则可以捕获future1过程以及userValue可能产生的异常。
catchError方法的参数为最常用的是第一个Function onError参数,同then的第二个参数
总结:future的then回调类似于一种观察这模式一样,可见使用await的方法并不适合添加then方法,因为then主要目的是在future完成的时候再来处理value从而避免阻塞,而await直接暴力的阻塞当前线程来等待future的完成