1. 借助JDK, 选取几个String与StringBuffer 、StringBuilder的常用API,并编写实例测试API的功能。
- String
- valueOf();
语法:valueOf(int i);将其他类型的数据转化为字符串。
int a = 10;
String s = String.valueOf(a);
System.out.print(s); // 10
- substring();
语法:substring(int beginIndex, int endIndex);提取子字符串。
String s = "123456";
String s1 = s.substring(0,3);// 123
System.out.println(s1);
- StringBuffer
- append();
语法:字符串.append(参数);将参数连接到字符串后并返回。
StringBuffer sb = new StringBuffer("青春无悔");
int num=10;
StringBuffer append = sb.append(num);
System.out.println(append);
- toString();
语法:字符串.toString();将字符串转换为String类的对象并返回。
String a="Hello";
String s1 = a.toString();
- StringBuilder
- delete(int start, int end);移除此序列从start到end-1的字符串
deleteCharAt(int index);移除指定索引上的char
StringBuilder s = new StringBuilder("123");
StringBuilder s1 = new StringBuilder("456");
s.delete(0, 1);
s1.deleteCharAt(1);
System.out.println(s);// 23
System.out.println(s1);// 46
- append()
StringBuilder s = new StringBuilder("123");
StringBuilder s1 = new StringBuilder("456");
s.append(s1);
System.out.print(s);// 123456
2. 请简述String,StringBuffer,StringBuilder三者之间的共同点与区别,应该分别在何种场景下使用?
- 共同点:
- 内部实现基于字符数组,封装了对字符串处理的各种操作
- 可自动检测数组越界等运行时异常
- 区别:
- String内部实现基于常量字符数组,内容不可变;
StringBuffer、StringBuilder基于普通字符数组,数组大小可根据
字符串的实际长度自动扩容,内容可变 - 性能方面,对于字符串的处理,相对来说
StringBuilder >StringBuffer>String - StringBuffer线程安全;StringBuilder非线程安全
- String内部实现基于常量字符数组,内容不可变;
- 使用场景:
- String:在字符串不经常变化的场景中可以使用String类,例如常量的声明、少量的变量运算。
- StringBuffer:在频繁进行字符串运算(如拼接、替换、删除等),并且运行在多线程环境中,则可以考虑使用StringBuffer,例如XML解析、HTTP参数解析和封装。
- StringBuilder:在频繁进行字符串运算(如拼接、替换、和删除等),并且运行在单线程的环境中,则可以考虑使用StringBuilder,如SQL语句的拼装、JSON封装等。
3. 为什么不建议在for循环中使用“+”进行字符串拼接?
会不断循环新建对象,效率低下(一般在for循环外新建对象,在for循环内部使用append()
方法)
例:
int m = 1;
StringBuffer st = new StringBuffer("a"); //效率较高,只需新建一个对象
for(int i=0; i<10000;i++){
st.append(m);
}
4. 什么是字符串的编码与解码?请举例说明。
- 编码:将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);
printCharArray("unicode:",str.toCharArray()); //unicode字符集中对"中文"二字的对应代码
byte[] b =str.getBytes(“GB2312”); //编码:转为本地字符集GBK2312对应的代码
printByteArray("GB2312",b);
byte[] m =str.getBytes("ISO8859-1"); //转为ISO8859-1对应的代码
printByteArray("ISO8859-1",m); // ISO8859-1是英文字符集,没有对应的汉字代码,所以转化错误
}
catch(UnsupportedEncodingException e){
System.out.println("没有相应的字符集!");
}
}
}
运行结果:
- 解码:将本地字符集转换为Unicode字符集的过程
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());
}
}
运行结果: