自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Promise 和 Async/Await的區(qū)別

開發(fā) 前端
在 JavaScript 中,Promises? 和 Async/await 是處理異步操作的兩種不同方法。但它們之間關(guān)系密切。

如果你正在閱讀這篇文章,你可能已經(jīng)理解了 promise 和 async/await 在執(zhí)行上下文中的不同之處。

圖片

在 JavaScript 中,promises 和 async/await 是處理異步操作的兩種不同方法。但它們之間關(guān)系密切。

Promise

Promise 是最終導(dǎo)致異步操作完成或失敗的對(duì)象。Promise 可以處于三種狀態(tài)之一:待定、已完成或已拒絕。當(dāng)異步操作完成時(shí),Promise 要么以一個(gè)值實(shí)現(xiàn),要么以一個(gè)錯(cuò)誤被拒絕。

// 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 之上的語(yǔ)法糖。它為編寫異步代碼提供了一種更簡(jiǎn)潔的方法,使其更易于閱讀和編寫。使用 async/await,可以編寫看起來(lái)與同步代碼相似的異步代碼,而且它在引擎蓋下使用了 Promise。

在 async/await 中, async 關(guān)鍵字用于聲明異步函數(shù)。 await 關(guān)鍵字用于在繼續(xù)執(zhí)行函數(shù)之前等待承諾的解析。 await 關(guān)鍵字只能在 async 函數(shù)中使用。

// 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

差異

唯一的區(qū)別在于 promise 和 async/await 的執(zhí)行上下文。

當(dāng)創(chuàng)建 Promise 并啟動(dòng)異步操作時(shí),創(chuàng)建 Promise 后的代碼會(huì)繼續(xù)同步執(zhí)行。當(dāng) Promise 被解析或拒絕時(shí),附加的回調(diào)函數(shù)會(huì)被添加到微任務(wù)隊(duì)列中。微任務(wù)隊(duì)列會(huì)在當(dāng)前任務(wù)完成后,但在下一個(gè)任務(wù)從任務(wù)隊(duì)列中處理出來(lái)之前進(jìn)行處理。這意味著在創(chuàng)建 Promise 之后的任何代碼都將在執(zhí)行附加到 Promise 的回調(diào)函數(shù)之前執(zhí)行。

另一方面,在使用 async/await 時(shí), await 關(guān)鍵字會(huì)使 JavaScript 引擎暫停執(zhí)行 async 函數(shù),直到 Promise 解析或被拒絕。當(dāng) async 函數(shù)等待 Promise 解析時(shí),它不會(huì)阻塞調(diào)用棧,因此可以執(zhí)行任何其他同步代碼。一旦 Promise 解析完畢, async 函數(shù)將繼續(xù)執(zhí)行,并返回 Promise 的結(jié)果。如果被拒絕,則會(huì)拋出一個(gè)錯(cuò)誤值。

責(zé)任編輯:姜華 來(lái)源: 大遷世界
相關(guān)推薦

2017-04-10 15:57:10

AsyncAwaitPromise

2021-06-07 09:44:10

JavaScript開發(fā)代碼

2024-09-02 14:12:56

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

2012-07-22 15:59:42

Silverlight

2021-07-20 10:26:12

JavaScriptasyncawait

2022-08-27 13:49:36

ES7promiseresolve

2023-07-28 07:31:52

JavaScriptasyncawait

2024-12-30 08:22:35

2021-06-28 07:27:43

AwaitAsync語(yǔ)法

2020-10-23 10:10:59

Promise前端代碼

2022-11-21 09:01:00

Swift并發(fā)結(jié)構(gòu)

2017-08-02 14:17:08

前端asyncawait

2021-02-09 09:53:11

C#多線程異步
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)