Java中的RuntimeException与Exception的区别

发布时间 - 2026-01-07 00:00:00    点击率:
RuntimeException 是 unchecked 异常,编译器不强制处理;其子类及 Error 的子类均属 unchecked,而继承 Exception(非 RuntimeException)的为 checked 异常;是否受检取决于继承关系而非名称或发生时机。

RuntimeException 是 unchecked 异常,编译器不强制处理

Java 把 Exception 分成两大类:checked(受检)和 unchecked(非受检)。RuntimeException 及其子类属于 unchecked,意味着你调用一个可能抛出 NullPointerExceptionArrayIndexOutOfBoundsException 的方法时,编译器不会报错,也不要求你写 try-catch 或声明 throws

而普通 Exception(比如 IOExceptionSQLException)是 checked 的——不处理就编译失败。

  • 这是语言设计上的区分:checked 异常代表「预期外但可恢复的外部问题」(如文件不存在、网络超时),应由调用方显式决策;
  • unchecked 异常代表「程序逻辑错误」(空指针、越界、类型转换失败),本不该发生,修复代码比捕获更合理;
  • 别为了过编译而随便加 catch (Exception e) { },这会掩盖真正的 bug。

继承关系决定行为,不是名字决定的

是否为 unchecked,只看它是不是 RuntimeExceptionError 的子类。哪怕你自定义一个叫 MyBusinessException 的异常,只要它继承 Exception(而非 RuntimeException),它就是 checked 异常。

反过来说,如果你继承 RuntimeException 写了个 ValidationFailedException,它就自动变成 unchecked,无需 throws 声明。

  • 常见误区:以为“运行时异常”只发生在运行期——其实所有异常都发生在运行期,关键在编译期是否检查;
  • Exception 是父类,RuntimeException 是它的直接子类;
  • 不要因为某个异常类名里没 “Runtime” 就误判它是否受检,查源码或 IDE 的继承树最可靠。

该捕获哪个?看能否有意义地恢复

面对 RuntimeException,多数情况不该捕获——比如 NullPointerException 暴露的是你忘了判空,补上 if (obj != null) 才是正解,而不是包一层 try-catch 吞掉它。

但也有例外:框架层(如 Spring MVC)会统一捕获 RuntimeException 转成 HTTP 500;或者你在解析用户输入时,用 NumberFormatException 判定输入格式非法,这时捕获反而更清晰。

  • 能预判并主动规避的,优先改逻辑(如判空、校验集合 size);
  • 属于用户输入或外部数据导致的「可预期的失败」,且有明确 fallback 行为(如返回默认值、提示友好错误),可以捕获特定 RuntimeException
  • 永远避免 catch (Exception e)catch (RuntimeException e) 空处理,除非你真要记录日志后重新抛出。

自定义异常时,选 Exception 还是 RuntimeException?

取决于你希望调用方「必须处理」还是「自行决定是否处理」。例如:

public class InsufficientBalanceException extends Exception { ... } // 调用方必须 try 或 throws
public class InvalidTokenException extends RuntimeException { ... } // 调用方可选择忽略

微服务中常见做法:BusinessException 继承 RuntimeException,配合全局异常处理器统一返回 JSON 错误;而涉及 IO、资源访问的异常(如 ConfigLoadException)若希望启动阶段就失败,可设为 checked。

  • 如果异常表示「调用方应该知道并响应」,用 checked;
  • 如果异常表示「调用方很难提前预防,出了就该修代码」,用 unchecked;
  • Spring 的 DataAccessException 体系全继承 RuntimeException,就是为了不让 DAO 层代码被 throws 污染——这个设计取舍很典型。

最易被忽略的一点:同一个异常类,在不同模块语义可能不同。比如 IllegalArgumentException 在工具类里是 unchecked 逻辑错,在 API 入口层却可能被当作用户参数错误来捕获并返回 400 ——关键不在它是什么类,而在你用它表达什么意图。


# java  # js  # json  # 处理器  # access  # 工具  # ai  # 区别  # spring mvc 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  如何在景安服务器上快速搭建个人网站?  如何在IIS7中新建站点?详细步骤解析  详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南  Laravel如何使用Vite进行前端资源打包?(配置示例)  Laravel如何集成Inertia.js与Vue/React?(安装配置)  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  html5的keygen标签为什么废弃_替代方案说明【解答】  太平洋网站制作公司,网络用语太平洋是什么意思?  Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践  Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程  Java解压缩zip - 解压缩多个文件或文件夹实例  如何在阿里云部署织梦网站?  英语简历制作免费网站推荐,如何将简历翻译成英文?  高端网站建设与定制开发一站式解决方案 中企动力  香港服务器如何优化才能显著提升网站加载速度?  android nfc常用标签读取总结  微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】  WEB开发之注册页面验证码倒计时代码的实现  如何在 React 中条件性地遍历数组并渲染元素  如何在橙子建站中快速调整背景颜色?  非常酷的网站设计制作软件,酷培ai教育官方网站?  高防服务器租用首荐平台,企业级优惠套餐快速部署  使用PHP下载CSS文件中的所有图片【几行代码即可实现】  Laravel如何使用Gate和Policy进行授权?(权限控制)  详解Android图表 MPAndroidChart折线图  简历没回改:利用AI润色让你的文字更专业  Thinkphp 中 distinct 的用法解析  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  javascript基于原型链的继承及call和apply函数用法分析  如何快速选择适合个人网站的云服务器配置?  Laravel Seeder填充数据教程_Laravel模型工厂Factory使用  Python进程池调度策略_任务分发说明【指导】  Swift中swift中的switch 语句  敲碗10年!Mac系列传将迎来「触控与联网」双革新  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  Laravel Session怎么存储_Laravel Session驱动配置详解  百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭  Python文件操作最佳实践_稳定性说明【指导】  如何在橙子建站上传落地页?操作指南详解  网站图片在线制作软件,怎么在图片上做链接?  Python面向对象测试方法_mock解析【教程】  Win11怎么开启自动HDR画质_Windows11显示设置HDR选项  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?