javascript的一道题,求大佬讲解?

Promise.resolve().then(() => console.log(2)); new Promise((resolve, reject) => {
    resolve(); console.log(3);
}).then(() => console.log(4)); setTimeout(() => {  Promise.resolve().then(() => console.log(5));  setTimeout(() => console.log(7), 0);
}, 0); setTimeout(() => console.log(6), 0);

结果顺序是:3 2 4 6 5 7
有人能解释一下具体原因吗?不是太明白,尤其是settimeout的事件机制#前端#
全部评论
楼主,按你的输出来看,你应该是在 node 环境(浏览器环境下情况已经有人回答了,这里补充一下 node 环境的) node 下事件循环是多个阶段分别维护不同队列的,执行时把当前阶段的队列中的所有任务完成后再进入下一阶段,这也是为什么会顺序输出 6, 5, 7 的原因(先把 timer 队列中的执行完) 具体可以参考 node 官方文档: https://nodejs.org/zh-cn/docs/guides/event-loop-timers-and-nexttick/
点赞 回复 分享
发布于 2019-04-19 22:20
Promise.resolve().then(() => console.log(2)); newPromise((resolve, reject) => {     resolve();  console.log(3); }).then(() => console.log(4)); setTimeout(() => {  Promise.resolve().then(() => console.log(5));      setTimeout(() => console.log(7), 0); }, 0);  setTimeout(() => console.log(6), 0); 首先主代码进入执行栈, 遇到第一句,将该promise压入微任务队列, 遇到第二句,打印 3 同时将该微任务压入promise 遇到第三句,将该任务压入宏任务 ,遇到第四句 将该任务压入宏任务 到此 主任务执行完毕,开始执行 微任务(微任务优先宏任务)  打印语句2, 打印语句4 到此 微任务执行完毕,开始执行 宏任务 =》 将微任务压入队列,将宏任务压入队列   执行完毕后 检测是否有微任务如果有就执行 打印5, 执行完毕后打印 宏任务 6 ,7  因此顺序是  3 2 4 5 6 7  
点赞 回复 分享
发布于 2019-04-19 22:02
说下自己的理解,如有不正确望大佬指正 //首先script作为第一个宏任务进入主线程,遇到promise.then放到微任务Event Queue中,记为p1,遇到new promise里的console.log直接输出3,then被分发到微任务Event Queue中,记为p2 //遇到第一个setTimeout,其回调函数被分发到宏任务Event Queue中。记为setTimeout1 //又遇到了第二个setTimeout,其回调函数被分发到宏任务Event Queue中,记为setTimeout2 //一轮过后就输出了3 //然后查看微任务Event Queue,发现p1和p2,输出2,4 //此时第一轮事件循环正式结束 //然后查看宏任务Event Queue,发现setTimeout1,promise.then放入微任务Event Queue,setTimeout放入宏任务,记录setTimeout3, //查看微任务event queue,输出5,此时第二个宏任务结束, //查看宏任务Event Queue,发现setTimeout2,执行输出6,此时第三轮宏任务结束 //查看宏任务Event Queue,发现setTimeout3,执行输出7 //结果应该是3,2,4,5,6,7
点赞 回复 分享
发布于 2019-04-19 21:57
楼主我这边运行的是324567
点赞 回复 分享
发布于 2019-04-19 21:57
你只需要记住Promise的then回调属于微任务,setTimeout属于宏任务。直观上微任务比宏任务优先(底层恰恰相反,因为解析一段代码也属于宏任务)
点赞 回复 分享
发布于 2019-04-19 21:44

相关推荐

老粉都知道小猪猪我很久没更新了,因为秋招非常非常不顺利,emo了三个月了,接下来说一下我的情况吧本人是双非本 专业是完全不着计算机边的非科班,比较有优势的是有两段大厂实习,美团和字节。秋招面了50+场泡池子泡死的:滴滴 快手 去哪儿 小鹏汽车 不知名的一两个小厂其中字节13场 两次3面挂 两次2面挂 一次一面挂其中有2场面试题没写出来,其他的都是全a,但该挂还是挂,第三次三面才面进去字节,秋招加暑期总共面了22次字节,在字节的面评可以出成书了快手面了8场,2次实习的,通过了但没去,一次2面挂 最后一次到录用评估 至今无消息滴滴三面完 没几天挂了 所有技术面找不出2个问题是我回答不上来的,三面还来说我去过字节,应该不会考虑滴滴吧,直接给我干傻了去哪儿一天速通 至今无消息小鹏汽车hr 至今无消息美团2面挂 然后不捞我了,三个志愿全部结束,估计被卡学历了虾皮二面挂 这个是我菜,面试官太牛逼了拼多多二面挂 3道题也全写了 也没问题是回答不出来的 泡一周后挂腾讯面了5次 一次2面挂 三次一面挂,我宣布腾讯是世界上最难进的互联网公司然后还有一些零零散散的中小厂,但是数量比较少,约面大多数都是大厂。整体的战况非常惨烈,面试机会少,就算面过了也需要和各路神仙横向对比,很多次我都是那个被比下去的人,不过这也正常,毕竟谁会放着一个985的硕士不招,反而去招一个双非读化学的小子感觉现在互联网对学历的要求越来越高了,不仅仅要985还要硕士了,双非几乎没啥生存空间了,我感觉未来几年双非想要进大厂开发的难度应该直线上升了,唯一的打法还是从大二刷实习,然后苟个转正,不然要是去秋招大概率是炮灰。而且就我面字节这么多次,已经开始问很多ai的东西了,你一破本科生要是没实习没科研懂什么ai啊,纯纯白给了
不知名牛友_:爸爸
秋招你被哪家公司挂了?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务