zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    元素的定位问题
    报纸排版(分列示例)
    background的属性和背景图片定位的实例
    CSS选择器小结
    URL与图像格式
    MIME(Multipurpose Internet Mail Extensions)的简介
    介绍两种风格的URL
    门店销售讲究多
    软件项目中需求管理工作的重要性
    谈谈需求变更跟踪
  • 原文地址:https://www.cnblogs.com/breezemist/p/13614044.html
Copyright © 2011-2022 走看看