front-end-interview icon indicating copy to clipboard operation
front-end-interview copied to clipboard

宏任务和微任务的区别

Open Liqiuyue9597 opened this issue 4 years ago • 0 comments

  1. 宏任务:当前调用栈中执行的代码成为宏任务(主代码块,定时器等等)。
  2. 微任务: 当前(此次事件循环中)宏任务执行完,在下一个宏任务开始之前需要执行的任务,可以理解为回调事件(promise.then,proness.nextTick等等)。
  3. 宏任务中的事件放在task queue中,由事件触发线程维护;微任务的事件放在微任务队列中,由JS引擎线程维护。

运行机制

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

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

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

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

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

Liqiuyue9597 avatar Aug 27 '20 13:08 Liqiuyue9597