1、 借助JDK, 选取几个String与StringBuffer 、StringBuilder的常用API,并编写实例测试API的功能。
class test{
public static void main(String[] args){
String s1 = new String("hello");
StringBuffer s2 = new StringBuffer("good");
StringBuilder s3 = new StringBuilder("world");
System.out.println(s1.concat(" judy!"));
System.out.println(s1.replace('l', 'm'));
System.out.println(s1);//s1没有改变
String[] s4 = new String[2];
s4=s1.split("e");
System.out.println(s4[1]);
System.out.println(s2.replace(1, 3, "a"));
System.out.println(s2.reverse());
System.out.println(s2);//s2被改变了
System.out.println(s2.insert(2, "233"));
s2=s2.append(s1);
System.out.println(s2.length());
}
}
class test{
public static void main(String[] args){
int m = 1;
String s = "a";
long startTime1 = System.currentTimeMillis();
for(int i=0; i<100000;i++){
s = s + m ; //效率低下,需新建一万个对象
}
long endTime1 = System.currentTimeMillis();
System.out.println("程序运行时间:"+ (endTime1-startTime1)+"ms");
int n = 1;
StringBuffer st = new StringBuffer("a"); //效率较高,只需新建一个对象
long startTime2 = System.currentTimeMillis();
for(int i=0; i<100000;i++){
st.append(n);
}
long endTime2 = System.currentTimeMillis();
System.out.println("程序运行时间:"+ (endTime2-startTime2)+"ms");
int q = 1;
StringBuilder sd = new StringBuilder("a"); //效率较高,只需新建一个对象
long startTime3 = System.currentTimeMillis();
for(int i=0; i<100000;i++){
sd.append(q);
}
long endTime3 = System.currentTimeMillis();
System.out.println("程序运行时间:"+ (endTime3-startTime3)+"ms");
}
}
2、请简述String,StringBuffer,StringBuilder三者之间的共同点与区别,应该分别在何种场景下使用?
共同点:
- 内部实现基于字符数组,封装了对字符串处理的各种操作
- 可自动检测数组越界等运行时异常
不同点:
- String内部实现基于常量字符数组,内容不可变;StringBuffer、StringBuilder基于普通字符数组,数组大小可根据字符串的实际长度自动扩容,内容可变
- 性能方面,对于字符串的处理,相对来说:StringBuilder > StringBuffer > String
- StringBuffer线程安全;StringBuilder非线程安全
3、为什么不建议在for循环中使用“+”进行字符串拼接?
使用“+”进行字符串拼接,会首先生成一个StringBuilder对象,然后将后面的字符串加入StringBuilder对象,最后返回String类型时会生成一个String对象,因此一个拼接过程生成了2个对象,如果在循环里面使用这种方式进行串接,会生成非常多的对象,导致性能极差!因此在对多个字符串进行串接时最好使用StringBuilder或StringBuffer的append方法。
4、 什么是字符串的编码与解码?请举例说明。
- 编码:将Unicode字符集转换为本地字符集的过程。
举例如下:
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());
}
}