try{
retrun 3;
}catch{
e.printStackTrace();
}finally{
return 4;
}
//上边情况下,实际返回的是4;
try{
int x = 3;
retrun x;
}catch{
e.printStackTrace();
}finally{
x++;
}
//上边情况下,实际返回的3;
这是为什么呢? 因为finally的业务操作是在try业务操作的return返回调用者者之前执行。按照刚才第一种情况,实际情况是,执行完try中的业务逻辑就,return返回的操作会先存储到一个临时的堆栈中,此时不给调用者返回,随后执行finally中的业务代码。如果finally中有return操作,那么就会把finally中的return值与try中的return值进行替换。随后将最终数据返回给调用者。
try、catch、finally用法总结:
1、不管有没有异常,finally中的代码都会执行
2、当try、catch中有return时,finally中的代码依然会继续执行
3、finally是在return后面的表达式运算之后执行的,此时并没有返回运算之后的值,而是把值保存起来,不管finally对该值做任何的改变,返回的值都不会改变,依然返回保存起来的值。也就是说方法的返回值是在finally运算之前就确定了的。
4、finally代码中最好不要包含return,程序会提前退出,也就是说返回的值不是try或catch中的值