JavaScript-同步和异步任务

在 JavaScript 中,任务的执行分为 同步任务异步任务 。异步任务又进一步分为 宏任务(Macro Task)微任务(Micro Task)

同步任务

同步任务是按照代码顺序依次执行的任务,会阻塞后续代码的执行,直到当前任务完成。

异步任务

异步任务不会阻塞后续代码的执行,他们会在未来某个时间点执行

宏任务

宏任务是指那些在事件循环中被放入"宏任务队列"的任务。宏任务的执行通常会触发一次完整的事件循环迭代。通常包括:

  1. setTimeoutsetInterval:定时器任务。
  2. setImmediate(Node.js环境):立即执行的任务。
  3. requestAnimationFrame(浏览器环境):用于浏览器重绘和重排的任务。
  4. I/O操作(Node.js环境):文件读取、网络请求等。

宏任务的特点

  • 宏任务的执行会触发一次完整的事件循环迭代。
  • 宏任务队列中的任务按照先进先出(FIFO)的顺序执行。
  • 每次事件循环迭代中,宏任务队列中的任务会依次执行,直到队列为空。

微任务

微任务是指那些在事件循环中被放入"微任务队列"的任务。微任务的执行优先级高于宏任务,且会在当前执行栈清空后立即执行。常见的微任务包括:

  • Promise.then()Promise.catch()Promise.finally()
  • process.nextTick(Node.js)
  • MutationObserver(浏览器)

微任务的特点

  • 微任务的执行优先级高于宏任务。
  • 微任务队列中的任务会在当前执行栈清空后立即执行,而不是等待事件循环的下一次迭代。
  • 微任务队列中的任务会按照先进先出(FIFO)的顺序执行,直到队列为空。

事件循环的执行顺序

  1. 执行所有的同步任务
  2. 执行所有的微任务
  3. 执行一个宏任务
  4. 重复步骤2和3直至所有的任务完成

示例

js 复制代码
console.log("1. 同步代码开始");

setTimeout(() => { // 宏任务
  console.log("2. 宏任务:setTimeout");
});

Promise.resolve().then(() => { // 微任务
  console.log("3. 微任务:Promise.then");
});

console.log("4. 同步代码结束");

输出结果:

js 复制代码
1. 同步代码开始
4. 同步代码结束
3. 微任务:Promise.then
2. 宏任务:setTimeout

总结

  • 宏任务 :执行优先级较低,通常涉及事件循环的完整迭代,如setTimeoutsetIntervalsetImmediate等。
  • 微任务 :执行优先级较高,会在当前执行栈清空后立即执行,如Promise的回调、MutationObserverqueueMicrotask()等。
  • 执行顺序:事件循环会先执行同步代码,然后执行微任务队列,最后执行宏任务队列。
相关推荐
辻戋9 分钟前
从零实现React Scheduler调度器
前端·react.js·前端框架
徐同保11 分钟前
使用yarn@4.6.0装包,项目是react+vite搭建的,项目无法启动,报错:
前端·react.js·前端框架
Qrun1 小时前
Windows11安装nvm管理node多版本
前端·vscode·react.js·ajax·npm·html5
中国lanwp1 小时前
全局 npm config 与多环境配置
前端·npm·node.js
JELEE.2 小时前
Django登录注册完整代码(图片、邮箱验证、加密)
前端·javascript·后端·python·django·bootstrap·jquery
TeleostNaCl4 小时前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享
前端大卫6 小时前
为什么 React 中的 key 不能用索引?
前端
你的人类朋友6 小时前
【Node】手动归还主线程控制权:解决 Node.js 阻塞的一个思路
前端·后端·node.js
小李小李不讲道理7 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻7 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js