溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎樣進(jìn)行Javafor循環(huán)Map集合優(yōu)化實(shí)現(xiàn)

發(fā)布時(shí)間:2021-10-15 17:22:49 來源:億速云 閱讀:120 作者:柒染 欄目:編程語言

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)怎樣進(jìn)行Javafor循環(huán)Map集合優(yōu)化實(shí)現(xiàn),文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

我們?cè)谄渲星短籽h(huán)優(yōu)化小循環(huán)驅(qū)動(dòng)大循環(huán)的基礎(chǔ)上,借助Map集合高效的查詢性能來優(yōu)化嵌套for循環(huán)。

如果小循環(huán)和大循環(huán)的集合元素?cái)?shù)量分別為M和N,則雙層For循環(huán)的循環(huán)次數(shù)是M*N,隨著M和N的增長(zhǎng),對(duì)性能的影響越來越大。因此,本文考慮進(jìn)一步優(yōu)化,使得循環(huán)次數(shù)變?yōu)镸+N。利用下面的代碼來模擬測(cè)試兩種情況的性能:

import java.util.ArrayList;import java.util.List;import java.util.Map;import java.util.function.Function;import java.util.stream.Collectors;public class ForUpdate {  public static void main(String[] args) {//    for (int i = 0; i < 10000; i += 10) {//      loopGivenNum(i);//    }    for (int i = 10000; i < 100000; i += 10000) {      loopGivenNum(i);    }    System.out.println("----- done -----");  }  private static void loopGivenNum(int i) {    List<String> smallLoop = getLoopList(i);    List<String> bigLoop = getLoopList(2 * i);    long doByForTimes = doByFor(bigLoop, smallLoop);    long doByMapTimes = doByMap(bigLoop, smallLoop);    System.out.println("size " + i + ": " + doByForTimes + "," + doByMapTimes);  }  /**   * 獲取循環(huán)變量   * @param size 循環(huán)變量元素個(gè)數(shù)   */  private static List<String> getLoopList(int size) {    List<String> list = new ArrayList<>();    for (int i = 0; i < size; i++) {      list.add(String.valueOf(i));    }    return list;  }  private static long doByFor(List<String> bigLoop, List<String> smallLoop) {    long startTime = System.currentTimeMillis();    for (String str1 : smallLoop) {      for (String str2 : bigLoop) {        if (str1.equals(str2)) {          continue;        }      }    }    return System.currentTimeMillis() - startTime;  }  /**   * 使用 Map 優(yōu)化   * @param bigLoop   * @param smallLoop   */  private static long doByMap(List<String> bigLoop, List<String> smallLoop) {    long startTime = System.currentTimeMillis();    // 轉(zhuǎn)換成map    Map<String, String> loopMap = bigLoop.stream().collect(Collectors.toMap(k -> k, Function.identity()));    System.out.println(loopMap.size());    for (String str1 : smallLoop) {      if (loopMap.containsKey(str1)) {        continue;      }    }    return System.currentTimeMillis() - startTime;  }}

輸出結(jié)果:

size 10000: 756,97size 20000: 3091,8size 30000: 4342,7size 40000: 8848,7size 50000: 16317,7size 60000: 31652,7size 70000: 37078,7

由此可見,數(shù)據(jù)量越大嵌套For循環(huán)執(zhí)行時(shí)間越長(zhǎng),而使用Map后,縱使數(shù)據(jù)量增長(zhǎng)到了20w,執(zhí)行時(shí)間也維持在7ms左右。數(shù)據(jù)量小的時(shí)候,執(zhí)行結(jié)果就不再貼出來了。

結(jié)論:使用Map優(yōu)化后的方法執(zhí)行的效率比嵌套循環(huán)提高了很多很多。

上述就是小編為大家分享的怎樣進(jìn)行Javafor循環(huán)Map集合優(yōu)化實(shí)現(xiàn)了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI