Dart 和 Javascript 中的await 和 async的理解
首先需要说明一下Javascript的单线程:
运行在游览器中我们写的Javascript的确是只运行在一个线程里的:一个窗口,对应一个js线程。但是,游览器引擎提供的文件读取,Ajax请求等io操作,是不同于js运行线程的单独线程。这样,我们就能在 js中,发出Ajax请求,游览器引擎会启动新的下载线程进行处理,下载完成后,把数据传递给js线程。Js中的Promise, dart中的Future,都是类似的原理,最后一定要使用系统引擎接口,达到io操作 异步执行的效果。
有了上面的了解,在看 await 和 async的作用。
await 会一层一层运行到 游览器引擎 或者 Flutter 渲染引擎 提供的新线程接口(比如Ajax请求接口), 系统接口调用前的代码其实都被同步执行了,之后的代码 需要等到 系统接口返回结果后,才能继续执行。
所以 await 实际上并没有’分界线‘的作用---即await 前面的代码同步执行,await后面的代码异步执行。await后面的异步函数代码中的部分内容,也可能被同步执行,代码会一直运行到 【系统的异步接口】处,才算到了分界线(参加下图)。但是从执行的结果来看,await 确实达到了 “等待“ 的效果,因为我们并不关心【异步函数中的部分代码是否被执行了】,我们关心的是 【 await 的数据必须返回,才能再继续执行下面的代码】。
再推荐一篇讲解flutter 多线程的好文章 https://www.jianshu.com/p/54da18ed1a9e