思考:
我们在实际的开发中,如果需要进行字符串的频繁拼接,会有什么问题?
因为java中的字符串是不可变的,每一次拼接都会产生新字符串。
这样会占用大量的方法区内存,造成内存空间的浪费。
String s = "abc";
s += "hello";
上面的代码,就导致在方法区字符串常量池中创建了3个对象:
“abc”、“hello”、“abchello”
解决办法
1、如果以后需要进行大量的拼接操作,建议使用JDK中自带的:
java.lang.StringBuffer
java.lang.StringBuilder
2、StringBuffer底层实际上是一个byte[]数组
往StringBuffer中放字符串,实际上是放到byte数组当中
StringBuffer的初始容量是16
public class test1 {
public static void main(String[] args) {
/*
如何优化StringBuffer的性能?
在创建爱你StringBuffer的时候尽可能给定一个初始化容量
最好减少底层数组的扩容次数。预估一下,给一个大一些的初始化容量
*/
//创建一个初始化容量为16的byte[]数组(字符串缓冲区)
StringBuffer stringBuffer = new StringBuffer();
//拼接字符串,以后拼接字符串-调用append()方法
//append是追加的意思
stringBuffer.append("a");
stringBuffer.append("b");
stringBuffer.append("d");
stringBuffer.append(3.14);
stringBuffer.append(true);
//apend 方法底层在进行追加的时候,如果byte数组满了,会自动扩容
stringBuffer.append(100L);
System.out.println(stringBuffer.toString());
//abd3.14true100
}
}
StringBuffer和StringBuilder的区别
StringBuffer中的方法都有:synchronized关键字修饰,表示StringBuffer在多线程下运行时安全的
StringBuilder中的方法都没有synchronized关键字修饰,表示StringBuilder在多线程环境下运行是不安全的。
StringBuffer是线程安全的
StringBuilder是非线程安全的。