1. StringBuilder的append方法
append方法就是将字符串追加到当前StringBuilder实例的结尾。
//java.lang.StringBuilder
StringBuilder sb=new StringBuilder("abc");
sb.append("123");
System.out.println(sb);//输出abc123
2. String+String 和 StringBuilder的append()效率比较。
public static void main(String[] args) {
// TODO 自动生成的方法存根
String str = "";
StringBuffer sb = new StringBuffer();
long start = 0L;
long end = 0L;
start = System.currentTimeMillis();
for (int i = 0; i < 100000; i++) {
str = str + "a";
}
end = System.currentTimeMillis();
System.out.println("使用string的时间是:" + (end - start) + "毫秒!");
start = System.currentTimeMillis();
for (int i = 0; i < 100000; i++) {
sb.append("a");
}
end = System.currentTimeMillis();
System.out.println("使用StringBuffer的时间是:" + (end - start) + "毫秒!");
//System.out.println(getMax("aba"));
}
结果:
使用string的时间是:4471毫秒!
使用StringBuffer的时间是:3毫秒!
分析:
这完全不是在一个层次上,希望各位谨记!大量字符串连接一定要用append()方法,原因呢其实很简单,字符串连接每次都需要创建新的字符串对象来保存新串,这样。。。。。。你懂得!
3. String ,StringBuffer ,StringBuilder的区别
string
String类是不可变类,即一旦一个String对象被创建以后,包含在这个对象中的字符序列是不可改变的,直至这个对象被销毁。
这个是String类的解释,之前我看到这个情况,不能理解上述的解释,如下:
String a = "123";
a = "456";
// 打印出来的a为456
System.out.println(a)
此处明明就是修改成功了!但是为什么还说他是一个不可变类呢?
通过学习后,上述代码的过程的a对象的内存存储空间图:
从图中可以看出:
再次给a赋值时,并不是对原来堆中实例对象进行重新赋值,而是生成一个新的实例对象,并且指向“456”这个字符串,
a则指向最新生成的实例对象,之前的实例对象仍然存在,如果没有被再次引用,则会被垃圾回收。
StringBuffer
StringBuffer对象则代表一个字符序列可变的字符串,当一个StringBuffer被创建以后,通过StringBuffer提供的append()、insert()、reverse()、setCharAt()、setLength()等方法可以改变这个字符串对象的字符序列。一旦通过StringBuffer生成了最终想要的字符串,就可以调用它的toString()方法将其转换为一个String对象。
StringBuffer b = new StringBuffer("123");
b.append("456");
// b打印结果为:123456
System.out.println(b);
b对象的内存空间图:
所以说StringBuffer对象是一个字符序列可变的字符串,它没有重新生成一个对象,而且在原来的对象中可以连接新的字符串。
StringBuilder
StringBuilder类也代表可变字符串对象。实际上,StringBuilder和StringBuffer基本相似,两个类的构造器和方法也基本相同。不同的是:StringBuffer是线程安全的,而StringBuilder则没有实现线程安全功能,所以性能略高。
StringBuffer是如何实现线程安全的
StringBuffer类中实现的方法:
StringBuilder类中实现的方法:
StringBuffer类中的方法都添加了synchronized关键字,也就是给这个方法添加了一个锁,用来保证线程安全。
ps:
Java9改进了字符串(包括String、StringBuffer、StringBuilder)的实现。在Java9以前字符串采用char[]数组来保存字符,因此字符串的每个字符占2字节;
而Java9的字符串采用byte[]数组再加一个encoding-flag字段来保存字符,因此字符串的每个字符只占1字节。所以Java9的字符串更加节省空间,字符串的功能方法也没有受到影响。
参考:
https://blog.csdn.net/csxypr/article/details/92378336
https://blog.csdn.net/itchuxuezhe_yang/article/details/89966303