成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

不要在循環await啦,異步操作的六個最佳實踐!

開發 前端
前兩天有個同學在面試中被問到了一個問題:“如果在請求多個不同的接口,那么應該如何去做?” 該同學回答說:“我們可以把這些接口放到一個數組中,然后通過 for 循環來循環請求!”

Hello,大家好,我是 Sunday。

前兩天有個同學在面試中被問到了一個問題:“如果在請求多個不同的接口,那么應該如何去做?” 該同學回答說:“我們可以把這些接口放到一個數組中,然后通過 for 循環來循環請求!”

嗯...這確是是一個方式,不過這并不好。再加上異步問題現在已經成了面試中的常見問題,所以,今天咱們就來說一下 異步請求的最佳實踐,幫助大家解決異步編程,以及面試問題。

01:不使用 await 的循環請求

我們不應該在循環內使用 await。 而是可以利用 promise.all 方法:

// ?
async function fn(reqs) {
  const results = [];
  for (const req of reqs) {
    // 每次循環迭代都會延遲到整個異步操作完成
    results.push(await req);
  }
  return results;
}

// ?
async function fn(reqs) {
  // 存儲所有異步操作的 Promise
  const promises = reqs.map((req) => req);
  // 所有異步操作都已經開始,現在等待它們全部完成
  const results = await Promise.all(promises);
  return results
}

02:不要在 promise 中執行返回操作

不要在 Promise 構造函數中返回值。 從那里返回的值是無用的。 它們也不影響 Promise 的狀態。

  • 正確的方法是使用 resolve 傳遞值。
  • 如果有錯誤,則使用 reject 傳遞錯誤。
// ?
new Promise((resolve, reject) => {
    // 返回沒有意義
    if (b) {
        return result;
    }
});

// ?
new Promise((resolve, reject) => {
    // 利用 resolve 傳遞
    if (b) {
        resolve(result);
        return;
    }
});

03:避免競態問題

看以下代碼,你認為最終打印會是多少?

// ?
let totalPosts = 0;

async function getPosts(userId) {
  // 模擬獲取用戶的帖子數量
  const users = [{ id: 1, posts: 5 }, { id: 2, posts: 3 }];
  // 模擬異步延遲
  await sleep(Math.random() * 1000);
  // 返回對應用戶的帖子數量
  return users.find((user) => user.id === userId).posts;
}

async function sleep (time) {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      resolve()
    }, time)
  })
}

async function addPosts(userId) {
  // 將用戶的帖子數量加到總帖子數上
  totalPosts += await getPosts(userId);
}

// 并行地獲取兩個用戶的帖子數量,并在全部獲取完畢后輸出總帖子數
await Promise.all([addPosts(1), addPosts(2)]);
console.log('帖子數量:', totalPosts);

執行以上代碼,你可能會打印 3 或 5,而不是 8。

這個原因就是因為 競態條件 問題而導致的。當在單獨的函數調用中更新值時,更新不會反映在當前函數作用域中。 因此,這兩個函數都將其結果添加到初始的 TotalPosts 值 0 中。

以下是避免競態條件的方式:

// ?
let totalPosts = 0;

async function getPosts(userId) {
  const users = [{ id: 1, posts: 5 }, { id: 2, posts: 3 }];
  await sleep(Math.random() * 1000);
  return users.find((user) => user.id === userId).posts;
}

async function sleep (time) {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      resolve()
    }, time)
  })
}

async function addPosts(userId) {
  const posts = await getPosts(userId);
  totalPosts += posts; // 變量被讀取并立即更新
}

await Promise.all([addPosts(1), addPosts(2)]);
console.log('帖子數量:', totalPosts);

04:避免回調地獄

這個問題大家應該很好理解,直接看代碼即可

// ?
async1((err, result1) => {
  async2(result1, (err, result2) => {
    async3(result2, (err, result3) => {
      async4(result3, (err, result4) => {
        console.log(result4);
      });
    });
  });
});

// ?
const result1 = await asyncPromise1();
const result2 = await asyncPromise2(result1);
const result3 = await asyncPromise3(result2);
const result4 = await asyncPromise4(result3);
console.log(result4);

05:避免直接返回 await

盡量避免直接返回 await ,特別是在需要 try..catch 的時候:

// ?
async () => {
  try {
    return await getUser(userId);
  } catch (error) {
    // 輸出錯誤
  }
}

// ?
async () => {
  try {
    const user = await getUser(userId);
    return user;
  } catch (error) {
    // 輸出錯誤
  }
}

06:reject 最好配合 Error 使用

// ?
Promise.reject('這是一個錯誤');

// ?
Promise.reject(new Error('這是一個錯誤'));


責任編輯:武曉燕 來源: 程序員Sunday
相關推薦

2025-04-11 11:55:49

2013-03-06 09:26:20

云服務云實踐精準管理

2022-05-26 11:11:19

Kubernetes容器云安全

2025-03-13 00:00:05

2013-03-06 10:54:03

云服務實踐關鍵步驟

2011-10-28 16:21:02

數據虛擬化服務器

2021-10-08 08:00:00

Java開發功能

2021-07-19 10:06:30

數據治理數字化轉型CIO

2017-06-19 09:12:08

JavaScriptPromiseAsync

2020-07-24 00:41:18

物聯網項目物聯網IOT

2018-05-11 09:25:46

全閃存陣列實踐

2009-07-08 11:27:05

敏捷方法

2023-07-18 15:11:01

2021-08-07 09:32:23

數據治理數字化轉型CIO

2023-04-14 08:10:59

asyncawait

2020-03-16 08:00:00

物聯網項目物聯網IOT

2023-09-13 08:00:00

JavaScript循環語句

2025-05-12 01:33:00

異步函數Promise

2017-06-06 15:10:42

框架APP設計

2022-11-15 16:54:54

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一区二区三区国产好的精 | 亚洲欧洲精品成人久久奇米网 | 亚洲综合第一页 | 国产黄色在线观看 | 一级国产精品一级国产精品片 | 99精品国产一区二区三区 | 国产一区在线免费 | 精品久久一区二区 | 中文字幕日韩欧美一区二区三区 | 国产在线1区 | 日韩一级免费看 | 久久伊人影院 | 久久青青 | 久久骚| aa级毛片毛片免费观看久 | 国产91丝袜在线18 | 国产成人网 | 日韩中文字幕在线不卡 | 爱爱免费视频 | 欧美日韩在线国产 | 中文字幕亚洲视频 | 久久久久久免费毛片精品 | 欧美日韩在线一区二区 | 国产精品久久久久久av公交车 | 中文字幕日韩欧美 | 亚洲精品一区在线观看 | 亚洲视频在线观看免费 | 欧美成人一区二区 | 欧美性另类 | 中文字幕在线免费观看 | 91视频一88av | 一区二区在线不卡 | 国产精品高潮呻吟久久久久 | 亚洲成人激情在线观看 | 久草在线青青草 | 亚洲精品中文字幕 | 在线视频 中文字幕 | 天天看片天天干 | 美女天堂av| 欧美精品1区 | 精品国产免费一区二区三区演员表 |