<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>

          為什么 idea 建議去掉 StringBuilder,使用“+”拼接字符串

          共 6759字,需瀏覽 14分鐘

           ·

          2024-07-25 07:22

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


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

          來自:京東云開發(fā)者社區(qū)

          推薦一個程序員編程資料站:
          http://cxyroad.com

          tips:
          2024年IDEA最新激活方法教程,后臺回復(fù):激活碼

          CSDN免登錄復(fù)制代碼插件下載:CSDN復(fù)制插件

          以下是正文。




          各位小伙伴在字符串拼接時應(yīng)該都見過下面這種提示:
          內(nèi)容翻譯:報告StringBuffer、StringBuilder或StringJoiner的任何用法,這些用法可以用單個java.lang.String串聯(lián)來替換。使用字符串串聯(lián)可以使代碼更短、更簡單。只有當(dāng)?shù)玫降拇?lián)至少與原始代碼一樣高效或更高效時,此檢查才會報告。
          大家普遍認知中,字符串拼接要用 StringBuilder,那為什么 idea 會建議你是用“+”呢,那到底 StringBuilder  和 “+”有什么具體區(qū)別呢,我們一起來探究一下。

          1、普通拼接
          普通的幾個字符串拼接成一個字符串,直接使用“+” 因為教材等原因,當(dāng)前依舊有許多人拼接字符串時認為使用“+”耗性能,首選StringBuilder。
          實際上,從JDK5開始,Java編譯器就做了優(yōu)化,使用“+”拼接字符串,編譯器編譯后實際就自動優(yōu)化為使用StringBuilder。
          新建測試類StringTest,分別創(chuàng)建使用“+”拼接字符串和使用StringBuilder拼接字符串的方法;并新增Junit測試用例,分別調(diào)用拼接字符串100000次(這里不是循環(huán)拼接,而是執(zhí)行多次拼接,因為一次拼接耗時太少,看不出差異),打印耗時。

          /**
           * 使用+拼接字符串
           */

          public String concatenationStringByPlus(String prefix, int i) {
              return prefix + "-" + i;
          }

          /**
           * 使用StringBuilder拼接字符串
           */

          public String concatenationStringByStringBuilder(String prefix, int i) {
              return new StringBuilder().append(prefix).append("-").append(i).toString();
          }

          /**
           * 測試使用+拼接字符串耗時
           */

          @Test
          public void testStringConcatenation01ByPlus() {
              long startTime = System.currentTimeMillis();
              int count = 100000;
              for (int i = 0; i < count; i++) {
                  String str = concatenationStringByPlus("testStringConcatenation01ByStringBuilder:", i);
              }
              long endTime = System.currentTimeMillis();
              System.out.println("testStringConcatenation01ByPlus,拼接字符串" + count + "次,花費" + (endTime - startTime) + "秒");
          }


          /**
           * 測試使用StringBuilder拼接字符串耗時
           */

          @Test
          public void testStringConcatenation02ByStringBuilder() {
              long startTime = System.currentTimeMillis();
              int count = 100000;
              for (int i = 0; i < count; i++) {
                  String str = concatenationStringByStringBuilder("testStringConcatenation02ByStringBuilder:", i);
              }
              long endTime = System.currentTimeMillis();
              System.out.println("testStringConcatenation02ByStringBuilder,拼接字符串" + count + "次,花費" + (endTime - startTime) + "秒");
          }

          執(zhí)行Junit用例,看耗時統(tǒng)計輸出:

          testStringConcatenation01ByPlus,拼接字符串100000次,花費33
          testStringConcatenation02ByStringBuilder,拼接字符串100000次,花費36

          雖然有差異,但是差異極小,考慮到執(zhí)行了100000次,每次耗時的差異就更小了,而且程序執(zhí)行有各種因素影響執(zhí)行效率,可以認為耗時差不多。也可以多次執(zhí)行對比耗時差異,也可以發(fā)現(xiàn)基本一致。
          到class文件所在目錄,執(zhí)行 javap -c StringTest.class,對class文件進行反編譯,查看編譯后的代碼差異。這里不要使用Intellij idea和JD進行反編譯,因為反編譯有優(yōu)化,會都反編譯成“+”拼接的,看不出來編譯后的真正情況。
          從圖上可以看出兩種拼接方法反編譯后完全一樣,沒有差異,執(zhí)行效率自然也是一樣的。
          既然執(zhí)行效率一樣,從代碼簡潔利于閱讀考慮,推薦使用“+”拼接字符串。

          2、循環(huán)拼接
          循環(huán)拼接一個長字符串,建議使用StringBuilder,雖然“+”拼接字符串編譯后也會變成StringBuilder,但是每次循環(huán)處理都會new一個StringBuilder對象,耗時會大大增加。而直接使用StringBuilder,new一次就可以了,效率相對高。
          新增2個Junit測試用例,循環(huán)拼接10000次拼接一個字符串(次數(shù)少于上面的用例,因為拼接的是一個字符串,如果拼接次數(shù)太多,可能引發(fā)內(nèi)存溢出):

          /**
           * 循環(huán)使用+拼接字符串
           */

          @Test
          public void testLoopStringConcatenation03ByPlus() {
              long startTime = System.currentTimeMillis();
              int count = 10000;
              String str = "testLoopStringConcatenation03ByPlus:";
              for (int i = 0; i < count; i++) {
                  str = str + "-" + i;
              }
              System.out.println(str);
              long endTime = System.currentTimeMillis();
              System.out.println("testLoopStringConcatenation03ByPlus,拼接字符串" + count + "次,花費" + (endTime - startTime) + "秒");
          }

          /**
           * 測試循環(huán)使用StringBuilder拼接字符串耗時
           */

          @Test
          public void testLoopStringConcatenation04ByStringBuilder() {
              long startTime = System.currentTimeMillis();
              int count = 100000;
              StringBuilder stringBuilder = new StringBuilder("testLoopStringConcatenation04ByStringBuilder:");
              for (int i = 0; i < count; i++) {
                  stringBuilder.append("-");
                  stringBuilder.append(i);
              }
              String str = stringBuilder.toString();
              System.out.println(str);
              long endTime = System.currentTimeMillis();
              System.out.println("testLoopStringConcatenation04ByStringBuilder,拼接字符串" + count + "次,花費" + (endTime - startTime) + "秒");
          }

          執(zhí)行Junit用例,看耗時統(tǒng)計輸出:

          testLoopStringConcatenation03ByPlus,拼接字符串10000次,花費463
          testLoopStringConcatenation04ByStringBuilder,拼接字符串10000次,花費13

          可以看出,差異明顯,不在一個量級了。

          總結(jié)
          1. 單純的字符串拼接使用“+”,更快更簡潔。

          2. 循環(huán)拼接時使用“+”拼接字符串效率較低,推薦使用 StringBuilder。

          <END>

          推薦閱讀:

          如何搭建一臺永久運行的個人服務(wù)器?

          14 個 SpringBoot 優(yōu)化小妙招,寫代碼像寫詩

              
          程序員在線工具站:cxytools.com

          推薦一個我自己寫的工具站:http://cxytools.com,專為程序員設(shè)計,包括時間日期、JSON處理、SQL格式化、隨機字符串生成、UUID生成、隨機數(shù)生成、文本Hash...等功能,提升開發(fā)效率。

          ?戳閱讀原文直達!                                  朕已閱 

          瀏覽 116
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <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>
                  国产无套精品久久久久久 | 国产精品99久久久久久久久久久久 | 黄色成人在线视频 | 久久精品噜噜噜成人88Aⅴ | 午夜精品成人片免费 |