在Java异常处理和return嵌套使用时,执行顺序的测试
1.当在try中放置return
代码:
public class T2 {
public static void main(String[] args) {
T3 t3 = new T3();
t3.say();
}
}
class T3{
public String say(){
try{
return say2();//先执行return
}finally {
System.out.println(2);//再执行finally
return "2";
}
}
public String say2(){
System.out.println(1);
return "1";
}
}
代码执行结果
测试总结: 当在try块中执行return。先执行return后面的语句再执行finally 在执行return结束程序 return和finally的执行顺序:finally》return
2.在catch中放置return
代码:
public class T2 {
public static void main(String[] args) {
T3 t3 = new T3();
t3.say();
}
}
class T3{
public String say(){
try{
int i=1/0;
return say("1");
}catch (Exception e){
e.printStackTrace();
return say("2");
} finally {
return say("3");
}
}
public String say(String str){
System.out.println(str);
return str;
}
}
执行结果
测试总结:先执行catch中的return 后的语句 再执行finally语句 在执行return 结束程序 执行顺序 catch》finally
3.在try中抛出异常但是 不捕获异常 向上抛出,并且在finally中执行return
代码:
public class T2 {
public static void main(String[] args) {
T3 t3 = new T3();
t3.say();
}
}
class T3{
public String say(){
try{
int i=1/0;
return say("1");
}finally {
return say("3");
}
}
public String say(String str){
System.out.println(str);
return str;
}
}
执行结果
测试总结:在try中抛出异常但是 不捕获异常 向上抛出,并且在finally中执行return 代码会丢失try中的异常 当注释 finally中的return执行结果
总结 finally总是在return结束程序之前执行 但是是先在return 紧跟的语句执行之后 把结果压栈后存起来 在执行finally 后(finally中无return )返回压栈后的结果,finally有return 便直接返回return结果。 finally改变压栈的结果,基本变量不变,而压栈是对象那么压栈的内容是对象的地址的值,改变对象的属性还是生效。 尽量不要在finally中写return 因为会导致异常无法抛出到上层。