最近中文字幕高清中文字幕无,亚洲欧美高清一区二区三区,一本色道无码道dvd在线观看 ,一个人看的www免费高清中文字幕

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

為什么我們應(yīng)該將 Promise 對(duì)象存儲(chǔ)在變量中?

為什么我們應(yīng)該將 Promise 對(duì)象存儲(chǔ)在變量中?

慕尼黑8549860 2023-10-20 15:10:30
讓我們假設(shè)我們有一個(gè)函數(shù)可以解決如下所示的承諾:function timeoutPromise(interval) {  return new Promise((resolve, reject) => {    setTimeout(function(){      resolve("done");    }, interval);  });};讓我們假設(shè)我們以兩種不同的方式在異步函數(shù)中調(diào)用該函數(shù);慢速同步方式:async function timeTest() {  await timeoutPromise(3000);  await timeoutPromise(3000);  await timeoutPromise(3000);}這里我們只是直接等待所有三個(gè) timeoutPromise() 調(diào)用。隨后的每個(gè)任務(wù)都被迫等待直到最后一個(gè)任務(wù)完成,這將導(dǎo)致總運(yùn)行時(shí)間約為 9 秒。和快速異步方式:async function timeTest() {  const timeoutPromise1 = timeoutPromise(3000);  const timeoutPromise2 = timeoutPromise(3000);  const timeoutPromise3 = timeoutPromise(3000);  await timeoutPromise1;  await timeoutPromise2;  await timeoutPromise3;}在這里,我們將三個(gè) Promise 對(duì)象存儲(chǔ)在變量中,這會(huì)導(dǎo)致它們的關(guān)聯(lián)進(jìn)程全部同時(shí)運(yùn)行。這將導(dǎo)致總運(yùn)行時(shí)間約為 3 秒。但問(wèn)題是,為什么將 Promise 對(duì)象存儲(chǔ)在變量中會(huì)導(dǎo)致相關(guān)進(jìn)程同時(shí)運(yùn)行?幕后發(fā)生了什么?
查看完整描述

1 回答

?
拉風(fēng)的咖菲貓

TA貢獻(xiàn)1995條經(jīng)驗(yàn) 獲得超2個(gè)贊

await foo();
await bar();

僅在解決了返回的 Promise才會(huì)調(diào)用bar(從而創(chuàng)建第二個(gè) Promise)。foo

var x = foo();
var y = bar();
await x;

在解決返回的承諾之前調(diào)用bar(從而創(chuàng)建第二個(gè)承諾) 。foo

這就是承諾“同時(shí)”的原因。如果您在不同的地方添加,console.log您將看到執(zhí)行上的差異:

function timeoutPromise(name, interval) {

  return new Promise((resolve, reject) => {

    console.log(`Promise ${name} created.`);

    setTimeout(function(){

      console.log(`Promise ${name} resolved.`);

      resolve("done");

    }, interval);

  });

};


async function timeTest1() {

  console.log('test 1');

  await timeoutPromise(1, 3000);

  console.log('between promise 1 and 2');

  await timeoutPromise(2, 3000);

}


async function timeTest2() {

  console.log('test 2');

  const timeoutPromise1 = timeoutPromise(1, 3000);

  console.log('between promise 1 and 2');

  const timeoutPromise2 = timeoutPromise(2, 3000);


  await timeoutPromise1;

  console.log('between promise 1 and 2 with await');

  await timeoutPromise2;

}


timeTest1().then(timeTest2);


查看完整回答
反對(duì) 回復(fù) 2023-10-20
  • 1 回答
  • 0 關(guān)注
  • 160 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)