受检异常与运行时异常区别详解
时间:2026-01-27 17:24:38 109浏览 收藏
“纵有疾风来,人生不言弃”,这句话送给正在学习文章的朋友们,也希望在阅读本文《受检异常与运行时异常的区别解析》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新文章相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!
受检异常必须显式处理,否则编译失败;即继承Exception(非RuntimeException子类)的异常需try-catch或throws声明,如IOException;运行时异常(如NullPointerException)继承RuntimeException,编译期不检查;Error(如OutOfMemoryError)不应捕获。

受检异常必须显式处理,否则编译失败
Java 编译器强制要求你对 Exception 及其子类(但不包括 RuntimeException)做处理:要么用 try-catch 捕获,要么在方法签名中用 throws 声明。这是编译期检查,不是运行时行为。
典型例子:IOException、SQLException、ClassNotFoundException。比如调用 FileInputStream 构造函数时抛出的 FileNotFoundException,不处理就过不了编译。
- 即使你确定该异常不会发生(比如读取 classpath 下的资源文件),也得写
try-catch或加throws - 过度使用受检异常会导致 API 设计僵硬,调用链层层
throws是常见反模式 - 自定义受检异常需继承
Exception,且不能是RuntimeException的子类
运行时异常继承 RuntimeException,编译器不管
RuntimeException 及其所有子类(如 NullPointerException、ArrayIndexOutOfBoundsException、IllegalArgumentException)属于运行时异常。它们在编译阶段完全不被检查,程序可以正常编译通过,只在运行时才可能抛出。
这类异常通常反映程序逻辑错误或非法输入,应该靠代码审查、单元测试和防御性编程来避免,而不是靠 try-catch 到处兜底。
- 不要在方法签名里声明
throws NullPointerException—— 没意义,编译器也不认 - 自定义运行时异常应继承
RuntimeException,而非直接继承Exception - 捕获
RuntimeException本身通常是危险信号,容易掩盖真实 bug
Throwable 是根,Error 一般不该捕获
所有异常都继承自 Throwable。Error(如 OutOfMemoryError、StackOverflowError)和 Exception 是它的两个并列子类。Error 表示严重系统问题,JVM 都可能无法继续运行。
除非你在写容器、框架或监控代理,否则不应该尝试捕获 Error:
- 捕获
OutOfMemoryError后几乎无法安全恢复,反而可能让状态更混乱 ThreadDeath是Error的子类,已被废弃,不要依赖- 写日志或清理资源可以放在
finally或try-with-resources中,而不是靠 catch Error
如何快速判断一个异常是受检还是运行时?
看它的直接父类是不是 RuntimeException。不是?再往上查,只要最终继承自 Exception 且**没经过 RuntimeException**,就是受检异常。
IDE 里按住 Ctrl(Windows)或 Cmd(macOS)点进去看类定义最准。命令行下也可以用:
javap -s java.lang.NullPointerException
输出中若显示 Ljava/lang/RuntimeException; 就是运行时异常;若显示 Ljava/lang/Exception; 且没有 RuntimeException 在继承链上,就是受检异常。
别靠名字猜——UnsupportedOperationException 听着像“不支持功能”该报错,但它其实是 RuntimeException 子类,完全不用声明。
终于介绍完啦!小伙伴们,这篇关于《受检异常与运行时异常区别详解》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
232 收藏
-
272 收藏
-
457 收藏
-
307 收藏
-
270 收藏
-
335 收藏
-
132 收藏
-
249 收藏
-
100 收藏
-
194 收藏
-
155 收藏
-
426 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习