有这么一段程序:
String a=new String("a");
String b="b";
String c=a+b;
StringBuffer strBuf=new StringBuffer();
strBuf.append("a");
strBuf.append("b");
String d=strBuf.toString();
StringBuilder strBuilder=new StringBuilder();
strBuilder.append("a");
strBuilder.append("b");
String e=strBuilder.toString();
请问以上程序片段中c、d、e的字符串的创建各有什么不同?
String a=new String("a");
String b="b";
String c=a+b;
StringBuffer strBuf=new StringBuffer();
strBuf.append("a");
strBuf.append("b");
String d=strBuf.toString();
StringBuilder strBuilder=new StringBuilder();
strBuilder.append("a");
strBuilder.append("b");
String e=strBuilder.toString();
请问以上程序片段中c、d、e的字符串的创建各有什么不同?
方法1:
创建String对象"a"
创建新的String对象a,复制拷贝了上一个String对象的值
创建String对象"b"
创建新的String对象引用b,指向上一个String对象的实例
新建StringBuilder对象x(JDK1.5之前是StringBuffer)
x.append(a)
x.append(b)
c=x.toString()方法2:
新建StringBuilder对象strBuf
strBuf.append("a") ("a"已经在常量池中,无需创建新对象)
strBuf.append("b") ("b"已经在常量池中,无需创建新对象)
d=strBuf.toString()方法3的实际流程基本等同于方法2,主要区别是StringBuffer是线程安全的,而StringBuilder不是,所以StringBuffer更安全而StringBuilder更快。