js学习-setTimeout,promise和async执行顺序

一道面试题

setTimeout(() => {
    console.log('setTimeout');
}, 0)

async function async1() {
    console.log('async1 start');
    await async2();
    console.log('async1 end');
}

async function async2() {
    console.log('async2');
}

console.log('script start');

async1();

new Promise((resolve) => {
	console.log('promise')
	resolve()
}).then(() => {
	console.log('promise.then')
})

console.log('script end');

输出结果:
在这里插入图片描述
为什么是这个结果呢?
首先定义了一个计时器:
在这里插入图片描述
它会被交给浏览器的定时器模块处理,当某个定时器到了可执行状态就会把该定时器扔到消息队列里去,最后执行。
然后定义了两个异步函数:
在这里插入图片描述
没有调用,所以没有输出。
然后我们终于碰到了第一个输出:
在这里插入图片描述
输出结果第一条。
接下去调用async1函数,当调用async函数的时候会返回一个Promise对象。Promise对象是立即执行的。
那就执行函数第一行的输出:
在这里插入图片描述
输出结果第二条。
然后就遇到了await async2,注意,这里的机制就是在async里遇到await,它会使async1函数暂停执行,这一步会执行到await的后面的内容,也就是执行async2后就暂停执行了。,async1就被扔到异步队列了。
那执行async2呗:
在这里插入图片描述
输出结果第三条。
再往下碰到了Promise:
在这里插入图片描述
Promise对象是立即执行的,所以立即输出结果的第四条。而后是执行了resolve。执行成功,执行成功的话会走入promise的.then方法里,可是它是异步的回调函数,所以会被丢入到异步队列里。那么现在异步队列里是未执行完的async1和promise的.then方法。
接下去就碰到最后一个输出。
在这里插入图片描述
输出结果第五条。
这时候同步队列已经全部执行完成。开始执行异步队列里的任务。而队列是先进先出,所以先执行未执行完的async1。
在这里插入图片描述
输出结果第六条。
async1执行完毕,然后执行promise的.then方法,输出结果第七条。
在这里插入图片描述
最后再执行消息队列里的setTimeout,输出结果第八条。
在这里插入图片描述
通过断点调试可以很清晰的观察到结果的输出。
在这里插入图片描述
注:如果是两个计时器,就按上面说的被交给浏览器的定时器模块处理,当某个定时器到了可执行状态就会把该定时器扔到消息队列里去,最后执行。
在这里插入图片描述
结果:
在这里插入图片描述
下面的计时器虽然被后定义,但先到时,所以先被加入消息队列,自然就被先执行。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值