finally中写return会强制使方法返回其值并吞掉异常。例如try返回1、finally返回2则实际返回2;try抛异常、finally返回42则异常消失,仅返回42。这是JVM控制流机制决定的,非覆盖行为,但严重破坏可读性与异常传播,不推荐使用。

在Java中,finally块里写return会导致try或catch中的return被忽略,方法会直接返回finally中的值。这不是“覆盖”,而是控制流的强制转移——JVM会确保finally执行完毕,并以其中的return为最终出口。
只要finally中有return语句,无论try或catch是否已执行了return,JVM都会丢弃之前准备好的返回值,转而执行finally中的return,并将其作为方法的最终返回结果。
如果try或catch抛出了未捕获的异常,但finally中执行了return,该异常将不会向上传播,调用方收不到异常,只会得到finally的返回值。这极易掩盖问题。
这是Java编程规范明确反对的做法。它破坏了方法的可读性、可预测性和异常传播逻辑,容易引发隐蔽bug。
立即学习“Java免费学习笔记(深入)”;
编译后,javac会把try/catch/finally合并为一个结构化异常表,并为每个可能出口插入“finally代码副本”。当遇到return时,JVM先暂存返回值,再跳入finally执行;若finally内有return,则直接用其操作数栈顶值作为最终返回,原暂存值被丢弃。
以上就是Java中的finally里写return会怎样_控制流冲突解析的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号