面试题2、讲一讲JS运行机制、微任务、宏任务、事件循环

1、JS代码从上往下执行,所有同步任务都会在主线程中执行,形成一个执行栈

2、主线程之外,还有一个任务队列,当发现一个异步任务,就塞一个事件(回调函数)到任务队列中等待;

3、一旦执行栈中所有同步代码执行完毕,系统就会读取任务队列,看看里面有哪些事件(回调函数)。于是结束等待状态,进入执行栈,开始执行。

4、主线程不断重复第三步,形成事件循环

===============================================================================

学习背景:事件循环 是 JavaScript 管理异步任务的核心机制,它遵循 "宏任务 → 清空所有微任务 → 渲染(如有需要)→ 下一轮宏任务" 的循环顺序执行,从而保证了代码的有序性和渲染的高效性。

js中,解释下宏任务与微任务,我没区分开这两个东西

**注意:微任务与宏任务都是异步任务**

终极一句话总结(面试满分)
1、同步优先,微任务插队,宏任务最后;
2、必须清空所有微任务,才会执行宏任务。
JS 执行顺序:同步先跑 → 微任务全清空 → 才跑下一个宏任务。

1. 什么是微任务(microtask)

可以理解成:JS 引擎自身的 "小任务",优先级更高。

常见微任务:

  1. Promise.then / catch / finally
  2. async/await(本质就是 Promise)
  3. queueMicrotask()
  4. MutationObserver

特点:会一次性全部执行完;只要有微任务,必须清空队列,才允许执行下一个宏任务;

2. 什么是宏任务(macrotask)

可以理解成:来自浏览器 / 宿主环境的 "大任务"。

==常见宏任务:

  1. setTimeout
  2. setInterval
  3. I/O 操作(ajax、fetch)
  4. UI 渲染
  5. requestAnimationFrame
  6. 事件队列(click、load 等)

特点:每次只执行一个;执行完必须等微任务全部清空,才会执行下一个宏任务。

3. 最关键的执行顺序(必考)

先执行 同步代码(立刻跑)

执行当前所有 微任务(全部清空)

然后 才执行下一个宏任务(一个)

再清空微任务 → 再下一个宏任务... 循环

4. 超级经典示例(一看就懂)

js 复制代码
console.log('1 同步')

setTimeout(() => {
  console.log('2 宏任务')
}, 0)

Promise.resolve().then(() => {
  console.log('3 微任务')
})

console.log('4 同步')

输出顺序:1 → 4 → 3 → 2

  • 1、4 是同步 → 最先执行
  • 3 是微任务 → 同步完立刻执行
  • 2 是宏任务 → 最后执行

5. 最容易搞混的点(我帮你点破)

await 后面的代码 = 微任务

setTimeout 永远比 Promise.then 慢

微任务可以插队宏任务!

微任务没清空,绝对不会执行下一个宏任务

相关推荐
九皇叔叔4 小时前
003-SpringSecurity-Demo 统一响应类
java·javascript·spring·springsecurity
低代码布道师5 小时前
纯代码实战:MBA培训管理系统 (十四) ——用户管理(批量选择与批量删除)
javascript·nextjs
Hello--_--World6 小时前
JavaScript运行机制、v8原理、js事件循环
开发语言·javascript·ecmascript
敲敲了个代码10 小时前
React 那么多状态管理库,到底选哪个?如果非要焊死一个呢?这篇文章解决你的选择困难症
前端·javascript·学习·react.js·前端框架
打瞌睡的朱尤10 小时前
js复习--考核
开发语言·前端·javascript
前端极客探险家10 小时前
React 全面入门与进阶实战教程
前端·javascript·react.js
程序员 沐阳11 小时前
异步编程深潜:事件循环、Promise 与 async/await 的底层真相
javascript
276695829211 小时前
zp_stoken 算法风控分析
java·前端·javascript·python·web逆向·boss直聘·zp_stoken
叫我一声阿雷吧11 小时前
JS 入门通关手册(38):防抖与节流 原理 + 手写 + 实战场景(面试必考)
javascript·性能优化·前端面试·防抖·节流·js手写题
妮妮喔妮11 小时前
组件的封装
开发语言·前端·javascript