答案:try-finally用于仅需资源清理而不处理异常的场景,异常会继续上抛;try-catch-finally则在捕获并处理异常的同时执行清理操作,适用于需统一处理和收尾的情况。

在Java中,try-finally 和 try-catch-finally 都用于确保某些代码无论是否发生异常都能执行,比如资源清理。它们的核心区别在于对异常的处理方式和使用场景。
try-finally:保证清理,不处理异常
这种结构只包含 try 块和 finally 块,没有 catch 块。它的主要作用是确保 finally 中的代码一定会执行,即使 try 中抛出了异常。
但需要注意的是,异常不会被拦截,会继续向上抛出。
适用场景:当你不需要在当前方法中处理异常,但仍需释放资源时使用。- try 块中可能发生异常
- finally 块总会执行,适合关闭文件、释放锁等操作
- 异常未被捕获,将传递给调用栈上层
示例:
立即学习“Java免费学习笔记(深入)”;
OutputStream out = new FileOutputStream("file.txt");
try {
out.write(123);
} finally {
out.close(); // 无论是否出错都尝试关闭
}
try-catch-finally:处理异常并清理资源
这种结构包含 try、catch 和 finally 三部分。它不仅能捕获并处理异常,还能保证 finally 中的代码执行。
catch 块用于处理特定类型的异常,防止程序中断;finally 依然负责清理工作。
适用场景:你需要在当前方法中对异常做出响应,同时完成资源释放。- catch 可以捕获并处理异常,避免程序崩溃
- finally 仍会执行,常用于统一收尾操作
- 可有多个 catch 块处理不同异常类型
示例:
立即学习“Java免费学习笔记(深入)”;
InputStream in = null;
try {
in = new FileInputStream("file.txt");
int data = in.read();
} catch (FileNotFoundException e) {
System.err.println("文件未找到:" + e.getMessage());
} catch (IOException e) {
System.err.println("读取失败:" + e.getMessage());
} finally {
if (in != null) {
try {
in.close();
} catch (IOException e) {
// 忽略或记录关闭异常
}
}
}
执行顺序与细节注意
无论哪种结构,finally 块都会在 try(和 catch)之后执行,除非JVM退出(如调用 System.exit())。
- 如果 try 中有 return 语句,finally 会在 return 前执行
- 若 finally 中也有 return,会覆盖 try/catch 中的 return 值(不推荐这样做)
- catch 捕获异常后,程序流程可继续,而 try-finally 中未捕获的异常会导致方法终止










