久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > java拼接字符串的方法

java拼接字符串的方法

來源:千鋒教育
發(fā)布人:qyf
時間: 2022-09-08 17:26:48 1662629208

java拼接字符串的方法

  java技術(shù)知識有很多,其中java拼接字符串就是其中的一種,本期小編要為大家介紹的是java拼接字符串的方法,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下。

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

  1.直接使用"+"號

  2.使用String的concat方法

  3.使用StringBuilder的append方法

  4.使用StringBuffer的append方法

  由于String是final類型的,因此String對象都是屬于不可變對象,因此,在需要對字符串進(jìn)行修改操作的時候(比如字符串的連接或者是替換),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通過編譯之后產(chǎn)生的字節(jié)碼文件

  public class com.fzkj.str.Str {

  public com.fzkj.str.Str();

  Code:

  0: aload_0

  1: invokespecial #1 // Method java/lang/Object."":()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."":()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

  }

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

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

  String str1 = "hello";

  String str2 = "wolrd";

  StringBuilder sb = new StringBuilder();

  sb.append(str1).append(str2);

  String s = sb.toString();

  在數(shù)據(jù)量很大的時候,比如說循環(huán)一萬次,那就會創(chuàng)建一萬個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("開始執(zhí)行時間:"+ startTime);

  for (int i = 0; i < 100000; i++) {

  String str = str1 + str2;

  }

  long stopTime = System.currentTimeMillis();

  System.out.println("結(jié)束執(zhí)行時間:"+ stopTime);

  System.out.println("執(zhí)行100000次字符串拼接總共耗時:"+(stopTime - startTime)+"ms");

  }

  }

  自媒體培訓(xùn)

  開始執(zhí)行時間:1591326544582

  結(jié)束執(zhí)行時間:1591326544601

  執(zhí)行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數(shù)組,將需要拼接的字符串放到這個數(shù)組中,最后轉(zhuǎn)換為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("開始執(zhí)行時間:"+ startTime);

  for (int i = 0; i < 100000; i++) {

  String str = str1.concat(str2);

  }

  long stopTime = System.currentTimeMillis();

  System.out.println("結(jié)束執(zhí)行時間:"+ stopTime);

  System.out.println("執(zhí)行100000次字符串拼接總共耗時:"+(stopTime - startTime)+"ms");

  }

  }

  開始執(zhí)行時間:1591328017552

  結(jié)束執(zhí)行時間:1591328017561

  執(zhí)行100000次字符串拼接總共耗時:9ms

  3.StringBuffer/StringBuilder

  這兩個類都繼承了同一個抽象類AbstractStringBuilder;而這兩個類的append方法都是調(diào)用的父類中的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;

  }

  而它倆的區(qū)別就是StringBuffer的append方法上加了synchronized關(guān)鍵字,因此是線程安全的。

  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("開始執(zhí)行時間:"+ startTime);

  for (int i = 0; i < 100000; i++) {

  sb.append(str1);

  }

  long stopTime = System.currentTimeMillis();

  System.out.println("結(jié)束執(zhí)行時間:"+ stopTime);

  System.out.println("StringBuffer執(zhí)行100000次字符串拼接總共耗時:"+(stopTime - startTime)+"ms");

  StringBuilder sb1 = new StringBuilder();

  long startTime1 = System.currentTimeMillis();

  System.out.println("開始執(zhí)行時間:"+ startTime1);

  for (int i = 0; i < 100000; i++) {

  sb1.append(str1);

  }

  long stopTime1 = System.currentTimeMillis();

  System.out.println("結(jié)束執(zhí)行時間:"+ stopTime1);

  System.out.println("StringBuilder執(zhí)行100000次字符串拼接總共耗時:"+(stopTime1 - startTime1)+"ms");

  }

  }

  開始執(zhí)行時間:1591328952926

  結(jié)束執(zhí)行時間:1591328952933

  StringBuffer執(zhí)行100000次字符串拼接總共耗時:7ms

  開始執(zhí)行時間:1591328952934

  結(jié)束執(zhí)行時間:1591328952936

  StringBuilder執(zhí)行100000次字符串拼接總共耗時:2ms

  StringBuilder的性能比StringBuffer的性能要好點。

  從上面的結(jié)果中,可以得出一個結(jié)論,那就是這四種的效率由快到慢依次是:

  StringBudiler>StringBuffer>concat>+

  事實上,在拼接的字符串很少的情況下,concat的效率其實是比StringBuilder的效率還要高的。

  所以在實際的使用過程中,要根據(jù)自己的需求選擇使用。。

  以上就是“java拼接字符串的方法”的詳細(xì)內(nèi)容,希望能夠幫助到大家,更多關(guān)于JAVA字符串拼接的資料請關(guān)注千鋒教育其它相關(guān)文章!

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
軟件定制開發(fā)中的敏捷開發(fā)是什么?

軟件定制開發(fā)中的敏捷開發(fā)是什么軟件定制開發(fā)中的敏捷開發(fā),從宏觀上看,是一個高度關(guān)注人員交互,持續(xù)開發(fā)與交付,接受需求變更并適應(yīng)環(huán)境變化...詳情>>

2023-10-14 13:24:57
什么是PlatformIo?

PlatformIO是什么PlatformIO是一個全面的物聯(lián)網(wǎng)開發(fā)平臺,它為眾多硬件平臺和開發(fā)環(huán)境提供了統(tǒng)一的工作流程,有效簡化了開發(fā)過程,并能兼容各種...詳情>>

2023-10-14 12:55:06
云快照與自動備份有什么區(qū)別?

1、定義和目標(biāo)不同云快照的主要目標(biāo)是提供一種快速恢復(fù)數(shù)據(jù)的方法,它只記錄在快照時間點后的數(shù)據(jù)變化,而不是所有的數(shù)據(jù)。自動備份的主要目標(biāo)...詳情>>

2023-10-14 12:48:59
服務(wù)器為什么要用Linux?

服務(wù)器為什么要用Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,Linux在眾多選擇中脫穎而出。Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,有其獨特的優(yōu)勢和特點。包括其...詳情>>

2023-10-14 12:34:11
ORM解決的主要問題是什么?

ORM(對象關(guān)系映射)解決的主要問題是將關(guān)系數(shù)據(jù)庫與面向?qū)ο缶幊讨g的映射困境。在傳統(tǒng)的關(guān)系數(shù)據(jù)庫中,數(shù)據(jù)以表格的形式存儲,而在面向?qū)ο?..詳情>>

2023-10-14 12:26:19
快速通道