本文讲解StringBuffer和StringBuilder的使用与区别。

1-- String

String类型我们已经很熟悉了,String一旦被赋值,其在堆中的数据便无法修改。

平时我们的“修改”都是直接在堆中创建一个新的字符串常量,然后重新引用这个新的字符串常量的。

//String 构造方法一旦被赋值,就不能被修改
        String s1 = "remoo";
        s1 = "aaa";
        String s2 = new String("REMMO");
        String s3 = new String(new char[] {'a','b'});

2-- StringBuffer

2-1 存储位置

与String不同的是StringBuffer的是可以被修改的。

StringBuffer也是储存在堆中,但是是在一个叫“缓冲区”的地方。

2-2 构造方法

构造方法有很多中,这里介绍两种。

StringBuffer sb = new StringBuffer("remoo");
StringBuffer sb1= new StringBuffer(10);//直接指定容量

第一种其实和String是一模一样的,不多介绍。

第二种是在开头指定了大小的。

2-3 append()方法

在原有的字符串后面增加。

sb.append(".rem");//追加字符串

那么现在sb存储的就是:remoo.rem

append()也可以接收各种数据

sb.append('o');
sb.append(100f);
sb.append(true);

现在存储的则是:remoo.remo100.0true

2-4 链式编程

这个比较好理解。

sb.append(true).append("链式调用").append("——链式编程");

现在存储的则是:remoo.remo100.0truetrue链式调用—链式编程

2-5 capacity()

sb.capacity()

返回的是当前sb占用的字节数。

2-6 自动扩容机制

我们不用担心存不下,如果当前内存块被写满了,则会自动扩容。

如果下一个内存地址被占用,无法扩容时,则会重新开辟内存地址,新开辟的容量一般是原来的一倍。

那么在申请新的地址的时候,必然会花费不少时间

大家可以用capacity方法检查一下。

2-7 delete方法

通过索引删除字节。

sb1.delete(0,3);//使用索引删除开始包含,结束不包含。

效果 :

调用前:12345678901

调用后:45678901

2-8 insert方法

通过索引插入字符串。

sb1.insert(3, "qqq");//在第三个字符处加..

调用前:45678901

调用后:456qqq78901

2-9 subString方法

通过索引获取

Show(sb1.substring(0,3));

返回456

2-10 replace方法

sb1.replace(0,3,"!");

调用前:456qqq78901
调用后:!qqq78901

3-- StringBuilder

使用起来和StringBuffer一模一样!

4-- StringBuffer和StringBuilder的区别

//线程安全相关的问题,后面具体说
//StringBuffer安全,但是效率没有Builder高
//多线程最好使用Buffer