Java修炼笔记7

本文探讨了Java中String、StringBuffer和StringBuilder的API实例、共同点与区别,以及适用场景。String不可变,适合常量;StringBuffer线程安全,适合多线程字符串操作;StringBuilder性能更高,适合单线程。不建议在循环中用“+”拼接字符串,因会导致大量对象创建。同时讲解了字符串的编码与解码概念。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

String,StringBuffer,StringBuilder常用API实例测试:

public class StringTest {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		String str1 = new String("abcde");  //创建String对象
		String str2 = "abcde";  //创建String对象
		System.out.println(str1 == str2);  //引用比较
		System.out.println(str1.equals(str2));  //值比较
		System.out.println(str1.length());  //字符串长度
		System.out.println(str1.startsWith("ab"));  //判断是否以给定字符串开头
		System.out.println(str1.indexOf("bcd"));  //判断是否包含指定字符串,包含则返回第一次出现该字符串的索引
		System.out.println(str1.contains("bcd"));  //判断是否包含指定字符串,包含返回true,不包含返回false
		char[] chs = str1.toCharArray();  //将字符串转成一个字符数组
		System.out.println(chs);
	}

}

运行结果:
false
true
5
true
1
true
abcde

public class StringBufferTest {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		String str1 = "abcde";
		StringBuffer str = new StringBuffer(str1);  //String对象转化为StringBuffer
		str.append("fg");  //在StringBuffer后增添一个新的字符串
		System.out.println(str);  
		System.out.println(str.charAt(5));  //读取字符串中指定位置的字符
		System.out.println(str.length());  //字符串长度
		System.out.println(str.indexOf("a"));  //判断是否包含指定字符串,包含则返回第一次出现该字符串的索引
		System.out.println(str.substring(1,4));  //读取内容为指定位置开始到指定位置结束所有字符
		System.out.println(str.delete(1,4));  //  删除指定位置开始到指定位置结束所有字符
		System.out.println(str.reverse());  //反转调用该方法的StringBuffer对象的值
	}

}

运行结果:
abcdefg
f
7
0
bcd
aefg
gfea

StringBuffer与StringBuilderAPI几乎一模一样。

String,StringBuffer,StringBuilder三者之间的共同点与区别以及应该分别在何种场合使用:

共同点:
都是字符串类,都可以创建和操作字符串。

区别:
String具有不可变性,String对象被创建以后,包含在这个对象中的字符序列是不可被改变的,而StringBuffer对象创建之后包含在这个对象中的字符序列可以被修改。StringBuilder类也代表可变字符串对象。实际上,StringBuilder和StringBuffer基本相似,两个类的构造器和方法也基本相同。不同的是:StringBuffer是线程安全的,而StringBuilder则没有实现线程安全功能,所以性能略高。

使用场合:
String:在字符串不经常变化的场景中可以使用String类,例如常量的声明、少量的字符串操作,用户名和密码。

StringBuffer:在频繁进行字符串运算(如拼接、替换、删除等),运行在多线程环境中并且要求线程安全,则可以考虑使用StringBuffer,例如XML解析、HTTP参数解析和封装。

StringBuilder:在频繁进行字符串运算(如拼接、替换、删除等),运行在单线程的环境中或者不要求线程安全,而对性能有一定要求,则可以考虑使用StringBuilder,如SQL语句的拼装、JSON封装等,StringBuilder可通过Synchronized解决多线程安全问题。

为什么不建议在for循环中使用“+”进行字符串拼接?

由于每次String对象在修改时都需要创建新的对象,因此在循环中使用“+”进行字符串拼接会产生大量的对象,从而占用大量的内存空间,可能导致计算机运行缓慢甚至内存崩溃。

字符串的编码与解码:

将unicode字符集转为本地字符集(如GB2312或GBK)的过程较编码,反之叫解码。

//编码
import java.io.*;
public class CharCode 
{  
  public static void printByteArray(String msg,byte[] t){
	System.out.println(msg+"****************");
    for(int i=0;i<t.length;i++){
      System.out.println(Integer.toHexString(t[i]));
    }
  }
  public static void printCharArray(String msg,char[] c){
	System.out.println(msg+"****************");
	for(int i=0;i<c.length;i++){
      System.out.println(Integer.toHexString(c[i]));
    }
  }
  public static void main(String[] args){
	try{
	  String str = "中文";
	  System.out.println(str);
	  //unicode字符集中对"中文"二字的对应代码
	  printCharArray("unicode:",str.toCharArray());   
	  //转为本地字符集GBK2312对应的代码
	  byte[] b =str.getBytes("GB2312");
	  printByteArray("GB2312",b);
	  //转为ISO8859-1对应的代码,因为ISO8859-1是英文字符集,
	  //没有对应的汉字代码,所以转化错误
	  byte[] m =str.getBytes("ISO8859-1");
	  printByteArray("ISO8859-1",m);
	}
	catch(UnsupportedEncodingException e){
		System.out.println("没有相应的字符集!");
	}
  }  
}
//解码
import java.io.*;

public class Decode{
  public static void printByteArray(String msg,byte[] t){
	System.out.println(msg+"****************");
    for(int i=0;i<t.length;i++){
      System.out.println(Integer.toHexString(t[i]));
    }
  }
  public static void printCharArray(String msg,char[] c){
	System.out.println(msg+"****************");
	for(int i=0;i<c.length;i++){
      System.out.println(Integer.toHexString(c[i]));
    }
  }
  public static void main(String[] args){
      byte[] b = new byte[6];
	  int t=0,pos=0;
	  String s;
      try
        {
	     while(t!='\n'){
		   t=System.in.read();
		   b[pos]=(byte)t;	     
		   pos++;
		 }
		 printByteArray("本地码:",b);
		 s = new String(b,"GBK");
		 System.out.println(s);
		 printCharArray("unicode码:",s.toCharArray());		 
	  }
      catch (Exception e)
      {
	    System.out.println(e.getMessage());
	  }	  
  }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值