字符串拼接+和concat的区别
2017-10-09 22:58
363 查看
+和concat都可以用来拼接字符串,但在使用上有什么区别呢,先来看看这个例子。
concat源码:
+左右可以为null,concat为会空指针。
如果拼接空字符串,concat会稍快,在速度上两者可以忽略不计,如果拼接更多字符串建议用StringBuilder。
从字节码来看+号编译后就是使用了StringBuiler来拼接,所以一行+++的语句就会创建一个StringBuilder,多条+++语句就会创建多个,所以为什么建议用StringBuilder的原因。
作者:架构之路
链接:http://www.jianshu.com/p/f91499424cea
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
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); }
所以可以得出以下结论:
+可以是字符串或者数字及其他基本类型数据,而concat只能接收字符串。+左右可以为null,concat为会空指针。
如果拼接空字符串,concat会稍快,在速度上两者可以忽略不计,如果拼接更多字符串建议用StringBuilder。
从字节码来看+号编译后就是使用了StringBuiler来拼接,所以一行+++的语句就会创建一个StringBuilder,多条+++语句就会创建多个,所以为什么建议用StringBuilder的原因。
作者:架构之路
链接:http://www.jianshu.com/p/f91499424cea
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
相关文章推荐
- 字符串拼接+和concat的区别
- mysql GROUP_CONCAT 拼接结果集字符串
- java语言基础(54)——变量字符串拼接和常量字符串拼接的区别
- JavaScript中使用concat()方法拼接字符串的教程
- mysql中如何用GROUP_CONCAT group by将字符串字段拼接起来
- StringBuilder String string.Concat 字符串拼接速度
- VBA中字符串连接/字符串拼接中“&”和“+”的区别
- JS拼接字符串单引号与双引号的区别
- WMSYS.WM_CONCAT(distinct(字段名)) 函数,字符串拼接函数。合并列
- php 拼接字符串 单引号与双引号的区别
- MYSQL 字符串拼接:CONCAT, CONCAT_WS, GROUP_CONCAT
- mysql 同列非数字字符串的拼接函数 group_concat
- mybatis中#{}【占位符】和${}【字符串】拼接的区别
- mysql下配置group_concat_max_len控制拼接字符串长度
- VBA中字符串连接/字符串拼接中“&”和“+”的区别
- 解决oracle数据库wm_concat()字符串拼接过长问题
- mysql 拼接字符串(concat函数&&concat_ws函数)
- StringBuilder与StringBuffer的区别(转) &精简版StringBuilder,提速字符串拼接
- GROUP_CONCAT()多条数据.拼接字符串 最大长度1024
- sql server 怎么实现mysql中group_concat,列转行,列用分隔符拼接字符串