黑马程序员_java学习笔记之(StringBuider&Stringbuffer)区别

------ <a href="http://www.itheima.com" target="blank">android培训</a>、<a href="http://www.itheima.com" target="blank">java培训</a>、期待与您交流! ----------

String概述

字符串是一个特殊的对象,字符串一旦初始化就不可以改变。所有字符串即使一个对象也是一个常量。
s1是一个类型变量,“abc”是一个对象
String s1 = "abc";
下面两句话作用是相同的,但是有区别
String s1 = "abc";
String s2 = new String("abc");
String类复写了Object类的equals方法,该方法用于判断字符串是否相同。

StringBuffer是字符串缓冲区
是一个容器。
什么时候用呢? 当数据类型不确定,最终变成字符串的时候用。
特点:
1.长度是可变化的。
2.可以字节操作多个数据类型。
3.最终会通过toString方法变成字符串。
C create U update R read D delete
1.存储。
StringBuffer append():将指定数据作为参数添加到已有数据结尾处。
StringBuffer insert(index,数据):可以将数据插入到指定index位置。
2.删除。
StringBuffer delete(int start,int end)删除缓冲区中的数据,包含start,不包含end.
StringBuffer deleteCharAt(index):删除指定位置的字符。
3.获取。
char charAt(int index)
int indexOf(String str)
int lastIndexOf(String str)
int length()
String substring(int start,int end)
4.修改。
StringBuffer replace(start,end,string);
void setCharAt(int index,char ch);
5.反转
StringBuffer reverse();
6.将缓冲区中指定的数据存储到指定字符数组中。
void getChars(int srcBegin,int srcEnd,char[] dst,int dstBegin)

JDK1.5版本之后出现了StringBuider.
StringBuffer 是线程同步。 安全 多线程中并发执行数据错乱,所以用同步:操作时其他不能动。
StringBuider 是线程不同步。 不安全,若为单线程时,Stringbuffer效率低,而Stringbuider不需要判断锁,比较快捷。
也就是说是单线程用StringBuider,是多线程用StringBuffer.
以后程序开发建议使用StringBuider.
升级但各因素:
1.提高效率
2.简化书写

3.提高安全性

 以下为各个方法的例子:
public class  stringbufferDemo
{
public static void main( String[] args)
{
/ /method_update();
//method_del();
//StringBuidersb=new StringBuider("abcdef");
//StringBuider StringBuffer 使用的方法是完全一样的,只是一个有锁一个没锁的关系。
StringBuffer sb=new  StringBuffer( "abcdef");
char[] chs= new char[6];
sb.getChars(1, 4,chs, 1); // 1 开始,到 4 结束,存入 chs 的数组中,在数组中从角标 1 开始存。
for( int x=0;x<chs.length;x++) {
sop( "chs[" +x+ "]=" +chs[x]+ ";" );
}
}
//更新
public static void method_update()
{
StringBuffer sb= new  StringBuffer( "abcd");
sb.replace(1, 3,  "java" );
sb.setCharAt( 2, 'k') ;
}
//删除
public static void method_del()
{
StringBuffer sb= new  StringBuffer( "abcde");
sb.delete(1, 3); // 包含头不包含尾
// 清空缓冲区
sb.delete(0,sb.length());
sb.delete(2,3 ); // 删除 C
sop(sb.toString());
}
//添加
public static void method_add()
{
StringBuffer sb= new  StringBuffer();
sb.append ( "abc" ).append(true).append(34);
sb.insert (1,  "qq" );
sop(sb.toString());//abctrue34
}
public static void sop( String str)
{
System.out.println(str);
}

}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: StringBuilder和StringBuffer都是用来操作字符串的类,它们之间的主要区别在于线程安全和执行速度。 StringBuffer是线程安全的,因为它的所有公共方法都被synchronized修饰,这意味着在多个线程同时访问时,StringBuffer可以保证数据的一致性。但是,由于每个方法都需要获取锁,因此它的执行速度相对较慢。 StringBuilder则是非线程安全的,它的执行速度比StringBuffer快,因为它的方法没有被synchronized修饰,所以不需要获取锁。但是,在多个线程同时访问时,StringBuilder不能保证数据的一致性。 因此,如果你需要在多个线程中操作字符串并且需要保证数据的一致性,建议使用StringBuffer;如果你只需要在单线程中操作字符串或者在多个线程中操作字符串但不要求数据的一致性,建议使用StringBuilder。 ### 回答2: StringBuilder和StringBuffer都是Java中用于处理可变字符串的类。它们的主要区别在于线程安全性和性能。 StringBuffer是线程安全的,这意味着它的方法在多线程环境下可以保持同步,不会出现数据不一致的问题。StringBuffer的每一个方法都是使用synchronized关键字修饰的,保证了线程安全性。因此,如果在多线程环境下进行字符串操作,推荐使用StringBuffer。 而StringBuilder则不是线程安全的。它的方法没有使用synchronized关键字修饰,因此在多线程环境下可能会出现数据不一致的问题。但是,由于没有同步开销,StringBuilder的执行速度比StringBuffer更快,所以在单线程环境下进行字符串操作时,推荐使用StringBuilder。 此外,由于StringBuffer是线程安全的,所以它的性能相对较低。在大部分情况下,如果不需要考虑线程安全性,使用StringBuilder会更加高效。 综上所述,StringBuilder和StringBuffer在线程安全性和性能方面有所不同。如果需要线程安全,使用StringBuffer;如果不需要线程安全,使用StringBuilder。 ### 回答3: StringBuilder和StringBufferJava中用于处理字符串的两个类,它们的最大区别在于线程安全性和执行速度。 1. 线程安全性:StringBuffer是线程安全的,而StringBuilder是非线程安全的。线程安全指的是在多线程环境下,对同一个对象的操作不会出现异常或数据错误。StringBuffer的方法都是使用synchronized关键字修饰的,所以它可以保证多线程环境下的安全操作。而StringBuilder没有使用synchronized关键字,所以它在多线程环境下的操作是不安全的。 2. 执行速度:由于StringBuffer是线程安全的,它的每个方法在执行时都会使用锁机制,以保证操作的原子性,这会导致一定的执行速度上的损耗。而StringBuilder是非线程安全的,不需要使用锁机制,所以它的执行速度相对较快。 基于以上两点,我们可以得出以下结论: 如果在单线程环境下,且不需要线程安全的操作,那么应该使用StringBuilder,因为它的执行速度更快。 如果在多线程环境下,或需要线程安全的操作,那么应该使用StringBuffer,虽然它的执行速度相对较慢,但可以保证线程安全。 根据具体需求,选择合适的类来处理字符串,能够更好地满足程序的要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值