async/await 处理异步操作详解

在 JavaScript 中,async/await 处理异步操作不会阻塞同步进程。它们的设计目的是使异步代码看起来像同步代码,从而提高代码的可读性和可维护性。async 函数返回一个 Promise 对象,而 await 关键字用于暂停 async 函数的执行,直到 Promise 解决(resolve)或拒绝(reject)。

详细解释

  1. async 函数

    • 使用 async 关键字定义的函数会自动返回一个 Promise 对象。
    • 函数内部可以使用 await 关键字来等待异步操作完成。
  2. await 关键字

    • await 只能在 async 函数中使用。
    • 它会暂停 async 函数的执行,直到等待的 Promise 解决或拒绝。
    • 这种暂停是非阻塞的,它不会阻塞 JavaScript 的事件循环或其他同步代码的执行。

示例代码

下面是一个示例,展示了 async/await 如何处理异步操作,以及它们与同步代码的执行顺序:

javascript 复制代码
console.log('Start'); // 同步代码

async function asyncFunction() {
  console.log('Inside asyncFunction'); // 同步部分
  await new Promise(resolve => setTimeout(resolve, 1000)); // 异步操作
  console.log('After await'); // 异步部分
}

asyncFunction(); // 调用 async 函数

console.log('End'); // 同步代码

解释

  1. 同步任务

    • console.log('Start')console.log('End') 是同步任务,会按顺序执行。
  2. 异步任务

    • 调用 asyncFunction() 会立即返回一个 Promise 对象,并执行 asyncFunction 内部的同步代码 console.log('Inside asyncFunction')
    • await new Promise(resolve => setTimeout(resolve, 1000)) 是异步操作,会暂停 asyncFunction 的执行,直到 Promise 解决。
    • console.log('After await') 会在异步操作完成后执行。

输出结果

plaintext 复制代码
Start
Inside asyncFunction
End
After await

结论

从输出结果可以看出,async/await 处理异步操作不会阻塞同步代码的执行。同步代码 console.log('End')asyncFunction 内部的异步操作完成前已经执行完毕。await 关键字暂停了 asyncFunction 的执行,但其他同步代码继续正常执行。

相关推荐
杨荧4 分钟前
【开源免费】基于Vue和SpringBoot的网上商城系统(附论文)
前端·javascript·jvm·vue.js·spring boot·spring cloud·开源
__night_19 分钟前
kiran-qt5-integration
java·前端·qt
小李老笨了20 分钟前
React组件化开发
前端·javascript·react.js
BillKu30 分钟前
vue3+ts+element-plus 表单el-form取消回车默认提交
前端·javascript·vue.js
鸠摩智首席音效师41 分钟前
如何修改 Angular 运行的主机和端口 ?
前端·javascript·angular.js
yuanbenshidiaos1 小时前
QT--------------常用的界面组件使用
前端·数据库·qt
Rattenking1 小时前
【CSS】 ---- CSS 实现图片背景清除的滑动效果三种方法
前端·javascript·css
关山月2 小时前
掌握package.json:全面指南🚀
前端
平行线也会相交2 小时前
云图库平台(四)——前端用户模块开发
前端·vue·云图库平台
rock——you2 小时前
quasar v2 setup语法中报错: undefined is not an object (evaluating ‘this.$q.notify‘)
前端·javascript·vue.js·quasar