直接看代码:
代码一:
public class Test { public static void main(String[] args) { System.out.println(new Test().test()); } static int test() { int x = 1; try { return x; } finally { ++x; } }}
结果:
1
这说明了什么问题?
finally块里面的代码总是在try块return之后执行?我们将代码稍作修改
代码二:
public class Test { public static void main(String[] args) { System.out.println(new Test().test()); } static int test() { int x = 1; try { return x; } finally { System.out.println("finally 块执行了..."); } }}
结果:
finally 块执行了...1
此时finally块好像又是在return之前执行的,我们继续修改代码
代码三:
public class Test { public static void main(String[] args) { System.out.println(new Test().test()); } static int test() { int x = 1; try { return x; } finally { ++x; return x; } }}
结果:
2
发现此时返回的是2!!!,那么finally块中的代码到底是在return之前执行呢还是在之后和执行呢?其实两者都不是,
确切的说应该在return返回中执行,可以这样理解,在try块中的代码return之后,会将return的值存储到数据栈中,此时
并未完全返回,然后去执行finally块,在代码一中,执行finally快的时候,数据栈中已经存储了return的值为1,即使
++x也不能改变返回值了,而代码二中,尽管数据栈中已经存储了return的值为1,但是在执行finally块的时候又return了一次,
直接覆盖了数据栈中的1变为了++x,即2。
因此做以总结,finally块是在try块还未完全return的时候执行的!!执行完finally块之后才会完全返回。