finally块总会执行,return先暂存返回值再执行finally;若finally含return则覆盖原返回值,否则返回暂存值;修改变量不影响已暂存的基本类型返回值。
Java规定:只要进入了try或catch块,无论其中是否执行了return,对应的finally块都会被执行(除非JVM提前退出,如调用System.exit())。这意味着return不是“立刻跳出方法”,而是先“记下返回值”,再执行finally,最后才真正返回。
如果try或catch中有return,JVM会把要返回的值**暂存**(基本类型存值,引用类型存地址),然后跳转到finally执行。若finally里没有return或throw,方法最终返回的就是这个暂存的值;但如果finally里也有return,它会**覆盖**之前暂存的返回值。
例如:
public static int test() { try { return 1; } finally { return 2; // ✅ 这个return生效,最终返回2 } }
对于基本类型,即使finally中修改了相关变量,也不会改变已暂存的返回值。
例如:
public static int test() {
int x = 1;
try {
return x; // 暂存x的值:1
} finally {
x = 2; // ✅ 修改x,但不影响已暂存的1
}
// 最终返回1
}
对引用类型同理:finally中修改对象属性会影响原对象(因为地址没变),但不会改变“return obj”时已确定的引用地址本身。
基本上就这些。理解“暂存返回值 + finally必执行 + 后者return可覆盖前者”,就能避开大部分坑。