String字符串拼接方法concat和+的效率對比
兩個方法效率計算代碼如下
public static void main(String[] args) {
String s1 = "a";
String str1="";
String str2="";
/**
* 計算concat所用時間
*/
long str1Start = System.currentTimeMillis();
for (int i=0;i<10000;i++){
str1=str1.concat(s1);
}
long str1End = System.currentTimeMillis();
System.out.println("concat計算時間為:" + (str1End - str1Start));
/**
* 計算+所用時間
*/
long str2Start = System.currentTimeMillis();
for (int i=0;i<10000;i++){
str2=str2+s1;
}
long str2End = System.currentTimeMillis();
System.out.println("+計算時間為:" + (str2End - str2Start));
}
多次測試結(jié)果如下




經(jīng)計算平均值為:
contact:45.75
+:123.75
結(jié)論為:
- concat的計算效率要比+的效率高
- concat只適用于string和string的拼接,+適用于string和任何的拼接
字符串拼接 和concat的區(qū)別
+和concat都可以用來拼接字符串,但在使用上有什么區(qū)別呢,先來看看這個例子。
public static void main(String[] args) {
// example1
String str1 = "s1";
System.out.println(str1 + 100);//s1100
System.out.println(100 + str1);//100s1
String str2 = "s2";
str2 = str2.concat("a").concat("bc");
System.out.println(str2);//s2abc
// example2
String str3 = "s3";
System.out.println(str3 + null);//s3null
System.out.println(null + str3);//nulls3
String str4 = null;
System.out.println(str4.concat("a"));//NullPointerException
System.out.println("a".concat(str4));//NullPointerException
}
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);
}
看下生成的字節(jié)碼:
所以可以得出以下結(jié)論:
- +可以是字符串或者數(shù)字及其他基本類型數(shù)據(jù),而concat只能接收字符串。
- +左右可以為null,concat為會空指針。
如果拼接空字符串,concat會稍快,在速度上兩者可以忽略不計,如果拼接更多字符串建議用StringBuilder。
從字節(jié)碼來看+號編譯后就是使用了StringBuiler來拼接,所以一行+++的語句就會創(chuàng)建一個StringBuilder,多條+++語句就會創(chuàng)建多個,所以為什么建議用StringBuilder的原因。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
MyBatis?超詳細(xì)講解動態(tài)SQL的實現(xiàn)
動態(tài)?SQL?是?MyBatis?的強大特性之一。如果你使用過?JDBC?或其它類似的框架,你應(yīng)該能理解根據(jù)不同條件拼接?SQL?語句有多痛苦,例如拼接時要確保不能忘記添加必要的空格,還要注意去掉列表最后一個列名的逗號。利用動態(tài)?SQL,可以徹底擺脫這種痛苦2022-03-03
使用Feign調(diào)用時添加驗證信息token到請求頭方式
這篇文章主要介紹了使用Feign調(diào)用時添加驗證信息token到請求頭方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03
Java Synchronized字節(jié)碼層分析體驗
這篇文章主要介紹了Java Synchronized字節(jié)碼層分析,synchronized關(guān)鍵字解決了多個線程之間的資源同步性,synchronized關(guān)鍵字保證了它修飾的方法或者代碼塊任意時刻只有一個線程在訪問2023-04-04

