<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          代碼中大量的套娃式for循環(huán),你有哪幾種方案可以?xún)?yōu)化?

          共 3222字,需瀏覽 7分鐘

           ·

          2021-08-29 10:14

          程序員的成長(zhǎng)之路
          互聯(lián)網(wǎng)/程序員/技術(shù)/資料共享 
          關(guān)注


          閱讀本文大概需要 2.8 分鐘。

          來(lái)源| aiyang
          鏈接| blog.csdn.net/csdn_aiyang/article/details/75162134

          前言

          我們都經(jīng)常使用一些循環(huán)耗時(shí)計(jì)算的操作,特別是for循環(huán),它是一種重復(fù)計(jì)算的操作,如果處理不好,耗時(shí)就比較大,如果處理書(shū)寫(xiě)得當(dāng)將大大提高效率,下面總結(jié)幾條for循環(huán)的常見(jiàn)優(yōu)化方式。
          首先,我們初始化一個(gè)集合 list,如下:
          List<String> list = new ArrayList<String>();

          方法一:最常規(guī)的不加思考的寫(xiě)法

          for (int i = 0; i < list.size(); i++) {
           System.out.println(list.get(i));
          }
          • 優(yōu)點(diǎn):較常見(jiàn),易于理解

          • 缺點(diǎn):每次都要計(jì)算list.size()

          方法二:數(shù)組長(zhǎng)度提取出來(lái)

          int m = list.size();
          for (int i = 0; i < m; i++) {
                System.out.println(list.get(i));
          }
          • 優(yōu)點(diǎn):不必每次都計(jì)算

          • 缺點(diǎn):

            1. m的作用域不夠小,違反了最小作用域原則
            2. 不能在for循環(huán)中操作list的大小,比如除去或新加一個(gè)元素

          方法三:數(shù)組長(zhǎng)度提取出來(lái)

          for (int i = 0, n = list.size(); i < n; i++) {
              System.out.println(list.get(i));
          }
          • 優(yōu)點(diǎn):不必每次都計(jì)算 ,變量的作用域遵循最小范圍原則

          • 缺點(diǎn):

            1. m的作用域不夠小,違反了最小作用域原則
            2. 不能在for循環(huán)中操作list的大小,比如除去或新加一個(gè)元素

          方法四:采用倒序的寫(xiě)法

          for (int i = list.size() - 1; i >= 0; i--) {
          System.out.println(list.get(i));
          }
          • 優(yōu)點(diǎn):不必每次都計(jì)算 ,變量的作用域遵循最小范圍原則

          • 缺點(diǎn):1、結(jié)果的順序會(huì)反 2、看起來(lái)不習(xí)慣,不易讀懂

          • 適用場(chǎng)合:與顯示結(jié)果順序無(wú)關(guān)的地方:比如保存之前數(shù)據(jù)的校驗(yàn)

          方法五:Iterator 遍歷

          for (Iterator<String> it = list.iterator(); it.hasNext();) {
                System.out.println(it.next());
          }
          • 優(yōu)點(diǎn):簡(jiǎn)潔

          方法六:jdk1.5后的寫(xiě)法

          for (Object o : list) {
               System.out.println(o);
          }
          • 優(yōu)點(diǎn):簡(jiǎn)潔結(jié)合泛型使用更簡(jiǎn)潔

          • 缺點(diǎn):jdk1.4向下不兼容

          方法七:循環(huán)嵌套外小內(nèi)大原則

          for (int i = 0; i < 10; i++) {
             for (int j = 0; j < 10000; j++) {
             }
          }
          原因

          方法八:循環(huán)嵌套提取不需要循環(huán)的邏輯

           //前:
           int a = 10, b = 11;
            for (int i = 0; i < 10; i++) {
                         i = i * a * b;
             } 
           
           
          //后:
           int c = a * b;
           for (int i = 0; i < 10; i++) {
                   i = i * c;
            }

          方法九:異常處理寫(xiě)在循環(huán)外面

          反例
          for (int i = 0; i < 10; i++) {
               try {
           
               } catch (Exception e) {
           
               }
          }
          正例
          try {
             for (int i = 0; i < 10; i++) {
             }
          catch (Exception e) {
           
          }
          <END>

          推薦閱讀:

          你偷看的小黃片,全被監(jiān)視了

          為什么代碼規(guī)范要求SQL語(yǔ)句不要過(guò)多的join?

          互聯(lián)網(wǎng)初中高級(jí)大廠(chǎng)面試題(9個(gè)G)

          內(nèi)容包含Java基礎(chǔ)、JavaWeb、MySQL性能優(yōu)化、JVM、鎖、百萬(wàn)并發(fā)、消息隊(duì)列、高性能緩存、反射、Spring全家桶原理、微服務(wù)、Zookeeper、數(shù)據(jù)結(jié)構(gòu)、限流熔斷降級(jí)......等技術(shù)棧!

          ?戳閱讀原文領(lǐng)?。?/span>                                       朕已閱 

          瀏覽 39
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          評(píng)論
          圖片
          表情
          推薦
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  午夜精品一区二区三区免费视频 | 91中文字幕人妻在线 | 中文字幕免费视频在线观看 | 午夜影院一区二区三区 | 爱爱无码AV |