Promise 和 Async/Await的区别

开发 前端
在 JavaScript 中,Promises​ 和 Async/await 是处理异步操作的两种不同方法。但它们之间关系密切。

如果你正在阅读这篇文章,你可能已经理解了 promise 和 async/await 在执行上下文中的不同之处。

图片

在 JavaScript 中,promises 和 async/await 是处理异步操作的两种不同方法。但它们之间关系密切。

Promise

Promise 是最终导致异步操作完成或失败的对象。Promise 可以处于三种状态之一:待定、已完成或已拒绝。当异步操作完成时,Promise 要么以一个值实现,要么以一个错误被拒绝。

// Using Promises
function promiseFunction() {
  return  new Promise((resolve, reject) => {
  setTimeout(() => {
    resolve("Resolved");
  }, 2000);
})
}

console.log("Start");
promiseFunction()
.then((result) => {
  console.log(result);
  console.log("End");
})
.catch((error)=>{
console.log(error)
});

Output:
Start
Resolved
End

Async/Await

async/await 是 Promise 之上的语法糖。它为编写异步代码提供了一种更简洁的方法,使其更易于阅读和编写。使用 async/await,可以编写看起来与同步代码相似的异步代码,而且它在引擎盖下使用了 Promise。

在 async/await 中, async 关键字用于声明异步函数。 await 关键字用于在继续执行函数之前等待承诺的解析。 await 关键字只能在 async 函数中使用。

// Using Async/Await
async function asyncFunction() {
  try {
    console.log("Start");
    const promise = new Promise((resolve, reject) => {
      setTimeout(() => {
        resolve("Resolved");
      }, 2000);
    });
    const result = await promise;
    console.log(result);
    console.log("End");
  } catch (error) {
    console.error(error);
  }
}

asyncFunction()

output:
Start
Resolved
End

差异

唯一的区别在于 promise 和 async/await 的执行上下文。

当创建 Promise 并启动异步操作时,创建 Promise 后的代码会继续同步执行。当 Promise 被解析或拒绝时,附加的回调函数会被添加到微任务队列中。微任务队列会在当前任务完成后,但在下一个任务从任务队列中处理出来之前进行处理。这意味着在创建 Promise 之后的任何代码都将在执行附加到 Promise 的回调函数之前执行。

另一方面,在使用 async/await 时, await 关键字会使 JavaScript 引擎暂停执行 async 函数,直到 Promise 解析或被拒绝。当 async 函数等待 Promise 解析时,它不会阻塞调用栈,因此可以执行任何其他同步代码。一旦 Promise 解析完毕, async 函数将继续执行,并返回 Promise 的结果。如果被拒绝,则会抛出一个错误值。

责任编辑:姜华 来源: 大迁世界
相关推荐

2017-04-10 15:57:10

AsyncAwaitPromise

2021-06-07 09:44:10

JavaScript开发代码

2021-05-18 07:52:31

PromiseAsyncAwait

2017-06-19 09:12:08

JavaScriptPromiseAsync

2014-07-15 10:31:07

asyncawait

2016-11-22 11:08:34

asyncjavascript

2023-03-29 10:19:44

异步编程AsyncPromise

2014-07-15 10:08:42

异步编程In .NET

2022-06-24 08:33:13

ECMAScriptjavaScript

2021-07-20 10:26:12

JavaScriptasyncawait

2012-07-22 15:59:42

Silverlight

2022-08-27 13:49:36

ES7promiseresolve

2020-10-23 10:10:59

Promise前端代码

2021-06-28 07:27:43

AwaitAsync语法

2023-07-28 07:31:52

JavaScriptasyncawait

2017-08-02 14:17:08

前端asyncawait

2022-11-21 09:01:00

Swift并发结构

2021-02-09 09:53:11

C#多线程异步

2022-06-13 07:36:47

useEffectHooks

2021-06-15 05:36:45

Gulpawaitasync
点赞
收藏

51CTO技术栈公众号