色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

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
相關文章:
主站蜘蛛池模板: 国产在视频线精品视频www666 | 国产精品私人玩物在线观看 | 午夜男人女人爽爽爽视频 | 台湾一级特黄精品大片 | 大视频在线爱爱爱爱 | 午夜三级理论在线观看视频 | 国亚洲欧美日韩精品 | 中文字幕亚洲精品 | 99爱视频在线观看 | 国产在线观看网址你懂得 | 精品毛片视频 | 久草视频免费在线播放 | 毛片一区二区三区 | 色三级大全高清视频在线观看 | 国产亚洲欧美精品久久久 | a级一级黄色片 | 日本三级午夜 | 亚洲午夜在线观看 | 国产精品每日更新在线观看 | 特黄特黄 | 在线观看精品视频网站www | 国产一级毛片视频 | 毛片在线免费视频 | 欧美日本一区视频免费 | 中国内地毛片免费高清 | 欧美黄网站 | 亚洲精品一区二三区在线观看 | 91在线精品亚洲一区二区 | 久久厕所精品国产精品亚洲 | 日本尹人综合香蕉在线观看 | 久在线观看视频 | 日本亚州视频在线八a | 日日摸日日碰夜夜爽久久 | 国产欧美一区二区三区沐欲 | 黄色片免费网址 | 杨幂国产精品福利在线观看 | 国产乱码精品一区二区三上 | 一级毛片美国 | 久久福利青草免费精品 | 国产成人一区二区在线不卡 | 一级 黄 色 片免费 一级aaaaaa毛片免费 |