亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

JAVA字符串拼接常見方法匯總

瀏覽:4日期:2022-08-31 10:31:23

字符串的拼接,常使用到的大概有4種方式:

1.直接使用'+'號

2.使用String的concat方法

3.使用StringBuilder的append方法

4.使用StringBuffer的append方法

由于String是final類型的,因此String對象都是屬于不可變對象,因此,在需要對字符串進行修改操作的時候(比如字符串的連接或者是替換),String總是會生成新的對象。

1.“+”

如果不考慮其他,使用“+”號來連接字符串無疑是最方便、最快捷的方式。但是事實上,使用“+”號連接字符串的效率并不高,。

貼出測試用的demo

public class Str { public static void main(String[] args) { String str1 = 'hello'; String str2 = 'wolrd'; String str = str1 + str2; System.out.println(str); }}

貼出Str通過編譯之后產生的字節碼文件

public class com.fzkj.str.Str { public com.fzkj.str.Str(); Code: 0: aload_0 1: invokespecial #1 // Method java/lang/Object.'<init>':()V 4: return public static void main(java.lang.String[]); Code: 0: ldc #2 // String hello 2: astore_1 3: ldc #3 // String wolrd 5: astore_2 6: new #4 // class java/lang/StringBuilder 9: dup 10: invokespecial #5 // Method java/lang/StringBuilder.'<init>':()V 13: aload_1 14: invokevirtual #6 // Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder; 17: aload_2 18: invokevirtual #6 // Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder; 21: invokevirtual #7 // Method java/lang/StringBuilder.toString:()Ljava/lang/String; 24: astore_3 25: getstatic #8 // Field java/lang/System.out:Ljava/io/PrintStream; 28: aload_3 29: invokevirtual #9 // Method java/io/PrintStream.println:(Ljava/lang/String;)V 32: return}

通過上面的字節碼文件可以看出,在執行String str = str1 + str2;這一條語句的時候,其實底層是調用了StringBuilder的append方法來實現,就是說使用“+”號連接字符串的時候,底層會new一個StringBuilder對象,調用該對象的append方法將字符串拼接起來,最后通過toString方法返回拼接之后的值。

也就是字符串str1+str2就等效于下面的代碼:

String str1 = 'hello';String str2 = 'wolrd';StringBuilder sb = new StringBuilder();sb.append(str1).append(str2);String s = sb.toString();

在數據量很大的時候,比如說循環一萬次,那就會創建一萬個StringBuilder對象。所以說使用'+'號拼接字符串的效率很低。

最后在看一下使用'+'號拼接str1和str2,100000次的耗時。

public class Str { public static void main(String[] args) { String str1 = 'hello'; String str2 = 'wolrd'; long startTime = System.currentTimeMillis(); System.out.println('開始執行時間:'+ startTime); for (int i = 0; i < 100000; i++) { String str = str1 + str2; } long stopTime = System.currentTimeMillis(); System.out.println('結束執行時間:'+ stopTime); System.out.println('執行100000次字符串拼接總共耗時:'+(stopTime - startTime)+'ms'); }}

開始執行時間:1591326544582結束執行時間:1591326544601執行100000次字符串拼接總共耗時:19ms

2.concat

concat源碼如下:

public String concat(String str) { int otherLen = str.length(); if (otherLen == 0) { return this; } int len = value.length; char buf[] = Arrays.copyOf(value, len + otherLen); str.getChars(buf, len); return new String(buf, true); }

從concat方法的源碼中可以看出來,concat就是申請了一個char數組,將需要拼接的字符串放到這個數組中,最后轉換為String返回。

還是記錄拼接100000次,總共的耗時

public class Str { public static void main(String[] args) { String str1 = 'hello'; String str2 = 'wolrd'; // 使用concat連接字符串 String concat = str1.concat(str2); long startTime = System.currentTimeMillis(); System.out.println('開始執行時間:'+ startTime); for (int i = 0; i < 100000; i++) { String str = str1.concat(str2); } long stopTime = System.currentTimeMillis(); System.out.println('結束執行時間:'+ stopTime); System.out.println('執行100000次字符串拼接總共耗時:'+(stopTime - startTime)+'ms'); }}

開始執行時間:1591328017552結束執行時間:1591328017561執行100000次字符串拼接總共耗時:9ms

3.StringBuffer/StringBuilder

這兩個類都繼承了同一個抽象類AbstractStringBuilder;而這兩個類的append方法都是調用的父類中的append方法。

public AbstractStringBuilder append(String str) { if (str == null) return appendNull(); int len = str.length(); ensureCapacityInternal(count + len); str.getChars(0, len, value, count); count += len; return this; }

而它倆的區別就是StringBuffer的append方法上加了synchronized關鍵字,因此是線程安全的。

public class Str { public static void main(String[] args) { String str1 = 'hello'; String str2 = 'wolrd';StringBuffer sb = new StringBuffer(); long startTime = System.currentTimeMillis(); System.out.println('開始執行時間:'+ startTime); for (int i = 0; i < 100000; i++) { sb.append(str1); } long stopTime = System.currentTimeMillis(); System.out.println('結束執行時間:'+ stopTime); System.out.println('StringBuffer執行100000次字符串拼接總共耗時:'+(stopTime - startTime)+'ms'); StringBuilder sb1 = new StringBuilder(); long startTime1 = System.currentTimeMillis(); System.out.println('開始執行時間:'+ startTime1); for (int i = 0; i < 100000; i++) { sb1.append(str1); } long stopTime1 = System.currentTimeMillis(); System.out.println('結束執行時間:'+ stopTime1); System.out.println('StringBuilder執行100000次字符串拼接總共耗時:'+(stopTime1 - startTime1)+'ms'); }}

開始執行時間:1591328952926結束執行時間:1591328952933StringBuffer執行100000次字符串拼接總共耗時:7ms開始執行時間:1591328952934結束執行時間:1591328952936StringBuilder執行100000次字符串拼接總共耗時:2ms

StringBuilder的性能比StringBuffer的性能要好點。從上面的結果中,可以得出一個結論,那就是這四種的效率由快到慢依次是:StringBudiler>StringBuffer>concat>+

事實上,在拼接的字符串很少的情況下,concat的效率其實是比StringBuilder的效率還要高的。所以在實際的使用過程中,要根據自己的需求選擇使用。。

以上就是JAVA字符串拼接常見方法匯總的詳細內容,更多關于JAVA字符串拼接的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 国产成人高清在线观看播放 | 宅男午夜剧场 | 欧美精品在线看 | 国产成人福利在线视老湿机 | 亚洲精品久久久久久久网站 | 欧美一级毛片一级 | 性做爰片免费视频毛片中文ilo | 亚洲欧美一区二区三区另类 | 在线免费观看黄色网址 | 国产亚洲精品高清在线 | a级成人毛片久久 | a毛片基地免费全部香蕉 | 亚洲精品午夜级久久久久 | 免费观看日本污污ww网站一区 | 韩国一级黄色 | 91国偷自产一区二区三区 | 一级做a爰片性色毛片黄书 一级做a爰片性色毛片新版的 | 国产精品久久久久久网站 | 久久要 | 五月婷婷综合色 | 伊人久久综合网亚洲 | 欧美久在线观看在线观看 | 性欧美一级毛片 | 一区二区三区高清在线观看 | 一级特级aa欧美毛片 | 尤物在线视频观看 | 久久久久亚洲精品中文字幕 | 欧美日韩在线第一页 | 国产美女在线免费观看 | 欧美一级视频在线观看 | 超级碰碰碰在线观看 | 婷婷综合在线观看丁香 | 伊人影院99 | 欧美日韩黄色 | 一级黄色免费网站 | 欧美综合图区亚欧综合图区 | 91久久亚洲精品国产一区二区 | 亚洲高清视频免费 | 啪啪网站在线观看 | 精品国产免费第一区二区三区日韩 | 免费观看一级特黄三大片视频 |