【java】学习路径17-StringBuffer、StringBuilder的使用与区别
Posted on 2022-03-18 22:16 罗芭Remoo 阅读(60) 评论(0) 编辑 收藏 举报本文讲解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