日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當(dāng)前位置:首頁 > 科技  > 軟件

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

來源: 責(zé)編: 時間:2024-04-15 18:12:41 186觀看
導(dǎo)讀Hello,大家好,我是 Sunday。前兩天有個同學(xué)在面試中被問到了一個問題:“如果在請求多個不同的接口,那么應(yīng)該如何去做?” 該同學(xué)回答說:“我們可以把這些接口放到一個數(shù)組中,然后通過 for 循環(huán)來循環(huán)請求!”嗯...這確是是一個

Hello,大家好,我是 Sunday。bh428資訊網(wǎng)——每日最新資訊28at.com

前兩天有個同學(xué)在面試中被問到了一個問題:“如果在請求多個不同的接口,那么應(yīng)該如何去做?” 該同學(xué)回答說:“我們可以把這些接口放到一個數(shù)組中,然后通過 for 循環(huán)來循環(huán)請求!”bh428資訊網(wǎng)——每日最新資訊28at.com

嗯...這確是是一個方式,不過這并不好。再加上異步問題現(xiàn)在已經(jīng)成了面試中的常見問題,所以,今天咱們就來說一下 異步請求的最佳實踐,幫助大家解決異步編程,以及面試問題。bh428資訊網(wǎng)——每日最新資訊28at.com

01:不使用 await 的循環(huán)請求

我們不應(yīng)該在循環(huán)內(nèi)使用 await。 而是可以利用 promise.all 方法:bh428資訊網(wǎng)——每日最新資訊28at.com

// ?async function fn(reqs) {  const results = [];  for (const req of reqs) {    // 每次循環(huán)迭代都會延遲到整個異步操作完成    results.push(await req);  }  return results;}// ?async function fn(reqs) {  // 存儲所有異步操作的 Promise  const promises = reqs.map((req) => req);  // 所有異步操作都已經(jīng)開始,現(xiàn)在等待它們?nèi)客瓿? const results = await Promise.all(promises);  return results}

02:不要在 promise 中執(zhí)行返回操作

不要在 Promise 構(gòu)造函數(shù)中返回值。 從那里返回的值是無用的。 它們也不影響 Promise 的狀態(tài)。bh428資訊網(wǎng)——每日最新資訊28at.com

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

03:避免競態(tài)問題

看以下代碼,你認(rèn)為最終打印會是多少?bh428資訊網(wǎng)——每日最新資訊28at.com

// ?let totalPosts = 0;async function getPosts(userId) {  // 模擬獲取用戶的帖子數(shù)量  const users = [{ id: 1, posts: 5 }, { id: 2, posts: 3 }];  // 模擬異步延遲  await sleep(Math.random() * 1000);  // 返回對應(yīng)用戶的帖子數(shù)量  return users.find((user) => user.id === userId).posts;}async function sleep (time) {  return new Promise((resolve, reject) => {    setTimeout(() => {      resolve()    }, time)  })}async function addPosts(userId) {  // 將用戶的帖子數(shù)量加到總帖子數(shù)上  totalPosts += await getPosts(userId);}// 并行地獲取兩個用戶的帖子數(shù)量,并在全部獲取完畢后輸出總帖子數(shù)await Promise.all([addPosts(1), addPosts(2)]);console.log('帖子數(shù)量:', totalPosts);

執(zhí)行以上代碼,你可能會打印 3 或 5,而不是 8。bh428資訊網(wǎng)——每日最新資訊28at.com

這個原因就是因為 競態(tài)條件 問題而導(dǎo)致的。當(dāng)在單獨的函數(shù)調(diào)用中更新值時,更新不會反映在當(dāng)前函數(shù)作用域中。 因此,這兩個函數(shù)都將其結(jié)果添加到初始的 TotalPosts 值 0 中。bh428資訊網(wǎng)——每日最新資訊28at.com

以下是避免競態(tài)條件的方式:bh428資訊網(wǎng)——每日最新資訊28at.com

// ?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('帖子數(shù)量:', totalPosts);

04:避免回調(diào)地獄

這個問題大家應(yīng)該很好理解,直接看代碼即可bh428資訊網(wǎng)——每日最新資訊28at.com

// ?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 的時候:bh428資訊網(wǎng)——每日最新資訊28at.com

// ?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('這是一個錯誤'));


bh428資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-83620-0.html不要在循環(huán)await啦,異步操作的六個最佳實踐!

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 要么返回錯誤值,要么輸出日志,別兩樣都做

下一篇: 聊聊如何使用 Python 實現(xiàn) RSA 加密

標(biāo)簽:
  • 熱門焦點
Top 主站蜘蛛池模板: 涿州市| 大同县| 拉萨市| 大竹县| 定襄县| 贡觉县| 新巴尔虎右旗| 大渡口区| 虹口区| 麻栗坡县| 会泽县| 太谷县| 潮安县| 华安县| 双柏县| 门源| 固镇县| 武义县| 修武县| 枣庄市| 内黄县| 永丰县| 夏邑县| 祁阳县| 垦利县| 武宁县| 辽宁省| 宕昌县| 德阳市| 西平县| 伊吾县| 普格县| 平定县| 通江县| 河北省| 新津县| 宁蒗| 大新县| 北川| 视频| 汤原县|