第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

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

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

慕尼黑8549860 2023-10-20 15:10:30
讓我們假設(shè)我們有一個函數(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);}這里我們只是直接等待所有三個 timeoutPromise() 調(diào)用。隨后的每個任務(wù)都被迫等待直到最后一個任務(wù)完成,這將導致總運行時間約為 9 秒。和快速異步方式:async function timeTest() {  const timeoutPromise1 = timeoutPromise(3000);  const timeoutPromise2 = timeoutPromise(3000);  const timeoutPromise3 = timeoutPromise(3000);  await timeoutPromise1;  await timeoutPromise2;  await timeoutPromise3;}在這里,我們將三個 Promise 對象存儲在變量中,這會導致它們的關(guān)聯(lián)進程全部同時運行。這將導致總運行時間約為 3 秒。但問題是,為什么將 Promise 對象存儲在變量中會導致相關(guān)進程同時運行?幕后發(fā)生了什么?
查看完整描述

1 回答

?
拉風的咖菲貓

TA貢獻1995條經(jīng)驗 獲得超2個贊

await foo();
await bar();

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

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

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

這就是承諾“同時”的原因。如果您在不同的地方添加,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);


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

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

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