×

前端面试题:聊聊宏任务与微任务以及它们的区别

作者:Terry2023.05.30来源:Web前端之家浏览:2393评论:0
关键词:宏任务微任务

前端面试题:聊聊宏任务与微任务以及它们的区别。

概念

1.宏任务:当前调用栈中执行的代码成为宏任务。(主代码快,定时器等等)。

2.微任务: 当前(此次事件循环中)宏任务执行完,在下一个宏任务开始之前需要执行的任务,可以理解为回调事件。(promise.then,proness.nextTick等等)。

3. 宏任务中的事件放在callback queue中,由事件触发线程维护;微任务的事件放在微任务队列中,由js引擎线程维护。

运行机制

在执行栈中执行一个宏任务。

执行过程中遇到微任务,将微任务添加到微任务队列中。

当前宏任务执行完毕,立即执行微任务队列中的任务。

当前微任务队列中的任务执行完毕,检查渲染,GUI线程接管渲染。

渲染完毕后,js线程接管,开启下一次事件循环,执行下一次宏任务(事件队列中取)。

微任务:process.nextTick、MutationObserver、Promise.then catch finally

宏任务:I/O、setTimeout、setInterval、setImmediate、requestAnimationFrame

您的支持是我们创作的动力!
温馨提示:本文作者系Terry ,经Web前端之家编辑修改或补充,转载请注明出处和本文链接:
https://jiangweishan.com/article/weirenwuhong.html

网友评论文明上网理性发言已有0人参与

发表评论: