浅谈宏任务和微任务

231 阅读1分钟

本文已参与「新人创作礼」活动,一起开启掘金创作之路。

宏任务和微任务

概念

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

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

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

运行机制

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

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

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

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

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

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

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

在执行过程中,微任务会高于宏任务优先执行,比如promise会优先于setTimeout执行。

js执行栈是单线程,但浏览器运行时是多线程。

比如: setTimeout会在计时器线程计时,计时到了之后把callback推入event loop,js执行栈里执行完之后,再把event loop里的callback拿过来执行。这也就是个宏任务。