0

0

Java中的RuntimeException与Exception的区别

P粉602998670

P粉602998670

发布时间:2026-01-07 14:21:09

|

908人浏览过

|

来源于php中文网

原创

runtimeexception 是 unchecked 异常,编译器不强制处理;其子类及 error 的子类均属 unchecked,而继承 exception(非 runtimeexception)的为 checked 异常;是否受检取决于继承关系而非名称或发生时机。

java中的runtimeexception与exception的区别

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 声明。

立即学习Java免费学习笔记(深入)”;

汉仪书宋一字体
汉仪书宋一字体

汉仪书宋一简是汉仪字库里面宋体的一种,与宋体字没什么区别,通常用于特殊提醒如批注中。

下载
  • 常见误区:以为“运行时异常”只发生在运行期——其实所有异常都发生在运行期,关键在编译期是否检查;
  • 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 ——关键不在它是什么类,而在你用它表达什么意图。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

156

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

88

2026.01.26

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

454

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

334

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1089

2024.03.01

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.3万人学习

C# 教程
C# 教程

共94课时 | 11万人学习

Java 教程
Java 教程

共578课时 | 80万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号