Java异常处理:try-catch使用教程
时间:2026-04-11 14:48:38 399浏览 收藏
本文深入剖析Java异常处理的核心实践与常见陷阱,从基础语法规范(如try-catch必须配对、子类异常须优先捕获)到高危误区(如滥用catch(Throwable)导致JVM错误静默崩溃),再到关键细节(finally中return会强制覆盖返回值、日志记录必须传入异常对象而非拼接字符串),全面揭示了看似简单却极易出错的异常处理机制;它不止教你“怎么写”,更引导你思考“该不该捕”“在哪捕”“捕后如何响应”,直击生产环境中排查困难、行为诡异、日志缺失等真实痛点,是每一位Java开发者夯实健壮性编码能力的必读指南。

try-catch 必须配对出现,不能只写 try 或只写 catch
Java 编译器会直接报错 error: try without catch, finally, or resource declarations。哪怕你只是想“先占个位置”,也得补上 catch 或 finally,光有 try 是非法语法。
常见错误现象:复制别人代码时漏掉了 catch 块,或者误删了大括号,导致 catch 不再属于该 try;IDE 有时会高亮提示但不明确说缺什么,容易卡住。
try后面必须紧跟一个或多个catch,或一个finally,或两者都有- 多个
catch要按“子类在前、父类在后”顺序排列,否则编译失败:error: exception XXX has already been caught - 如果用的是受检异常(比如
IOException),try块里没处理,又没在方法签名加throws,编译直接过不去
捕获 Exception 和 Throwable 的区别很关键
写成 catch (Exception e) 是常规操作;但有人图省事写成 catch (Throwable t),这会吞掉 OutOfMemoryError、StackOverflowError 这类 JVM 级别错误,导致程序静默崩溃、排查困难。
使用场景:日常业务逻辑里,绝大多数情况只需捕获 Exception 及其子类;只有极少数框架层或监控工具才需要捕获 Throwable,且必须立刻判断是否为 Error 并重新抛出。
- 永远不要在业务代码里用
catch (Throwable t)后直接log.info()然后继续执行 catch (RuntimeException e)是合法的,但它不抓IOException这类受检异常,容易漏处理- Java 7+ 支持多异常捕获:
catch (IOException | SQLException e),注意中间是|不是||
finally 里的 return 会覆盖 try/catch 中的 return
这是最容易被忽略的行为:只要 finally 里有 return,不管前面 try 或 catch 返回什么,最终方法返回值都是 finally 里的值。连异常都会被吃掉。
示例:以下代码实际返回 2,且不会抛出 NullPointerException:
public static int test() {
try {
throw new NullPointerException();
return 1;
} catch (Exception e) {
return 0;
} finally {
return 2;
}
}
finally适合做资源清理(如关闭InputStream),不适合放业务逻辑或return- Java 7+ 推荐用
try-with-resources替代手写finally关流,更安全简洁 - 如果真要在
finally里改状态,确保不破坏控制流,比如只调用close()或log.debug()
log 异常时必须用 e.printStackTrace() 的替代方案
直接写 e.printStackTrace() 会输出到 System.err,脱离日志系统,查问题时根本找不到上下文。生产环境基本等于“没记录”。
正确做法是把异常对象传给日志框架的 error() 方法,让框架自动打印堆栈:
logger.error("文件读取失败", e); // ✅ 正确:e 是第二个参数
- 不要拼字符串:
logger.error("文件读取失败: " + e.getMessage())—— 丢掉了堆栈 - 不要只打
e.getMessage(),很多异常信息为空,比如NullPointerException - 如果用 SLF4J,确保日志实现(Logback / Log4j2)已配置好,否则可能静默丢日志
try-catch 块本身解决。今天关于《Java异常处理:try-catch使用教程》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
224 收藏
-
470 收藏
-
450 收藏
-
387 收藏
-
192 收藏
-
452 收藏
-
149 收藏
-
354 收藏
-
166 收藏
-
293 收藏
-
321 收藏
-
196 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习