博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
详解promise、async和await的执行顺序
阅读量:5216 次
发布时间:2019-06-14

本文共 1848 字,大约阅读时间需要 6 分钟。

前言

对于promise、async和await的执行顺序,很多人都容易弄混,也有很多人只愿意在程序中运用一种,比如我只使用promise,不使用async和await;也有只用async和await,而不是用promise。所以现在来为大家讲讲一起共存需要注意写什么?

详解promise、async和await的执行顺序

示例

下面这段promise、async和await代码,请问控制台打印的顺序?

async function async1(){ console.log('async1 start') await async2() console.log('async1 end') } async function async2(){ console.log('async2') } console.log('script start') setTimeout(function(){ console.log('setTimeout') },0) async1(); new Promise(function(resolve){ console.log('promise1') resolve(); }).then(function(){ console.log('promise2') }) console.log('script end')
JavaScript
Copy

上述,在Chrome 66node v10中,正确输出是:

script startasync1 startasync2promise1script endpromise2async1 endsetTimeout
JavaScript
Copy

知识点

显然,这考察的是js中的事件循环和回调队列。注意以下几点:

Promise优先于setTimeout宏任务。所以,setTimeout回调会在最后执行。
Promise一旦被定义,就会立即执行。
Promiserejectresolve是异步执行的回调。所以,resolve()会被放到回调队列中,在主函数执行完和setTimeout前调用。
await执行完后,会让出线程。async标记的函数会返回一个Promise对象

难点

最令人困惑的,就是async1 endpromise2之后输出

在函数async1中,执行promise由于async2async标记的函数,所以默认返回promise对象)会发现resolve(),然后放入回调队列。

接着执行下方的new Promise中的resolve()输出promise2,再回来输出async1 end

其中,async1函数可以写成以下方式(便于理解):

async function async1(){ console.log('async1 start') async2().then( _ => { console.log( 'async1 end ') }) }
JavaScript
Copy

流程

1.  `console.log('script start')`输出:`script start`2.  `setTimeout`被放在最后调用3.  执行`async1`函数,输出`async1 start`。然后,进入`async2`函数,输出`async2`,并返回`Promise`对象。回到`async1`,由于`await`,让出线程,`async2`函数返回的`Promise`放在**回调队列**。4.  新new了一个`Promise`对象,输出`promise1`。其中的`resolve()`被放在回调队列。5.  `console.log('script end')`输出:`script end`6.  执行回调队列中,`async1`返回的`Promise`对象,对象产生的`resolve`被放入对调队列。这里不输出任何值。7.  执行回调队列中,下方`Promise`显式声明的`resolve`,输出`promise2`。8.  执行回调队列中,由于`async1`函数返回的`promise`对象的`resolve`,输出`async1 end`。9.  执行回调队列中,最后的`setTimeout`,输出`setTimeout`10.  finish

转载于:https://www.cnblogs.com/shaozhu520/p/11341030.html

你可能感兴趣的文章
优步中国:2月底前进军广东、湖南、湖北18个城市
查看>>
滴滴快车历史奖励政策:含工作日和周末的高峰奖励、翻倍奖励【历史政策】...
查看>>
ubuntu 16.04 安装chrome的方法
查看>>
轻快的VIM(一):移动
查看>>
【bzoj4571 scoi2016】美味
查看>>
文件操作类2
查看>>
'System.Web.Http.GlobalConfiguration' does not contain a definition for 'Configure'
查看>>
游戏偶感
查看>>
Leetcode: Unique Binary Search Trees II
查看>>
转载------------Python多线程学习
查看>>
判断是否是微信浏览器
查看>>
Beta 冲刺(5/7)
查看>>
博客作业03--栈和队列
查看>>
phpcurl类
查看>>
Hadoop伪分布式搭建
查看>>
第二章:07字符
查看>>
C++ FFLIB 之FFDB: 使用 Mysql&Sqlite 实现CRUD
查看>>
APP性能测试
查看>>
apache开源项目-- Turbine
查看>>
vue打包时semver.js版本报错
查看>>