异常分析
1.String 和StringBuffer的区别
JAVA平台提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据。这个String类 提供了数值不可改变的字符串。而这个StringBuffer类提供的字符串进行修改。当你知道字符数据要改变的时候你就可以使用 StringBuffer。典型地,你可以使用StringBuffers来动态构造字符数据。另外,String实现了equals方法,new
String(“abc”).equals(new
String(“abc”)的结果为true,而StringBuffer没有实现equals方法,所以,new
StringBuffer(“abc”).equals(new StringBuffer(“abc”)的结果为false。
import java.util.Date;public class Test { public static void main(String[] args) { long startTime = System.currentTimeMillis(); String str = new String("a"); for(int i=0;i<100000;i++) { str = str+1; } long endTime = System.currentTimeMillis(); System.out.println(endTime-startTime+"*-*-*-*-**-"); long startTime1 = System.currentTimeMillis(); StringBuffer sb = new StringBuffer("a"); for(int i=0;i<100000;i++) { sb = sb.append(1); } long endTime1 = System.currentTimeMillis(); System.out.println(endTime1-startTime1+"*-*-***-*-*-*-*-*---*-*-*-*-*-*"); } }
2、数组有没有length()这个方法? String有没有length()这个方法?
数组没有length()这个方法,有length的属性。String有有length()这个方法
3.下面这条语句一共创建了多少个对象:String s=“a”+“b”+“c”+"d"
String s1 = "a";
String s2 = s1 + "b";
String s3 = "a" + "b";
System.out.println(s2 == "ab");
System.out.println(s3 == "ab");
第一条语句打印的结果为false,第二条语句打印的结果为true,这说明javac编译可以对字符串常量直接相加的表达式进行优化,不必要等到运行期去进行加法运算处理,而是在编译时去掉其中的加号,直接将其编译成一个这些常量相连的结果。
题目中的第一行代码被编译器在编译时优化后,相当于直接定义了一个”abcd”的字符串,所以,上面的代码应该只创建了一个String对象。写如下两行代码,
String s = "a" + "b" + "c" + "d";
System.out.println(s == "abcd");
最终打印的结果应该为true。
4.try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,什么时候被执行,在return前还是后
public class Test2 {
public static void main(String[] args) {
System.out.println(new Test2().test());
}
static int test() {
int x= 1;
try {
return x;
} catch (Exception e) {
}finally {
++x;
}
return 0;
}
}
**---------执行结果 ---------**
1
运行结果是1,为什么呢?主函数调用子函数并得到结果的过程,好比主函数准备一个空罐子,当子函数要返回结果时,先把结果放在罐子里,然后再将程序逻辑返回到主函数。所谓返回,就是子函数说,我不运行了,你主函数继续运行吧,这没什么结果可言,结果是在说这话之前放进罐子里的。
5.下面的程序代码输出的结果是多少
public class Test2 {
public static void main(String[] args) {
System.out.println(new Test2().test());;
}
int test()
{
try
{
return func1();
}
finally{
return func2();
}
}
int func1()
{
System.out.println("func1");
return 1;
}
int func2()
{
System.out.println("func2");
return 2;
}
}
结论:finally中的代码比return 和break语句后执行