0

0

在Java里throwable类和exception类有什么区别_Java异常类层级解析

P粉602998670

P粉602998670

发布时间:2026-02-06 10:29:02

|

755人浏览过

|

来源于php中文网

原创

Throwable 是异常体系根类,Exception 是其专用于可预期、可恢复问题的子类;应优先捕获 Exception 而非 Throwable,自定义异常须继承 Exception 或 RuntimeException,禁直接继承 Throwable。

在java里throwable类和exception类有什么区别_java异常类层级解析

Throwable 是异常体系的根,Exception 是它的一个子类

Java 所有能被 throwcatch 的对象,必须是 Throwable 或其子类的实例。它本身不能直接 new(构造器是 protected),但它的两个直接子类可以:ErrorException。而 Exception 就是专为“程序可预期、可恢复”的问题设计的——比如文件找不到、网络超时、空指针访问等。

换句话说:Throwable 是“所有异常和错误”的统称;Exception 是其中“你该管、也能管”的那一部分。

catch (Throwable e) 会捕获 Error,这通常是个坏主意

catch (Throwable e) 看似“兜底”,实际风险很大:

  • 它会把 OutOfMemoryErrorStackOverflowError 这类 JVM 已经快崩了的严重错误也吞掉,导致程序继续跑在不可靠状态里
  • 你几乎无法对 Error 做有意义的恢复(比如重试、降级、日志补救),强行 catch 反而掩盖了真正的问题
  • 绝大多数业务代码应该只用 catch (Exception e),它天然过滤掉 Error,专注处理你能 handle 的异常

例外场景极少:比如你在写一个通用监控代理、JVM 启动引导器,或者明确要记录并上报所有崩溃信号——才考虑捕获 Throwable,且之后应立即退出或重启。

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

爱AI工具库
爱AI工具库

爱AI工具库是一个实用的AI工具导航网站

下载

Exception 分两类:编译器强制你管的(Checked),和不强制但常出错的(Unchecked)

Exception 下又分两支:

  • IOExceptionSQLException 这类是 Checked Exception:方法签名里必须 throws,或用 try-catch 包住,否则编译失败
  • NullPointerExceptionIllegalArgumentException 这些属于 RuntimeExceptionException 的子类),是 Unchecked Exception:编译器不管,但运行时一出就中断线程

关键区别不在“能不能 catch”,而在于设计意图:Checked 表示“这个异常大概率会发生,你得提前想好怎么应对”;Unchecked 表示“这是代码逻辑缺陷,应该修复,而不是靠 try-catch 掩盖”。

别继承 Throwable 写自定义异常,优先继承 Exception 或 RuntimeException

自己定义异常类时:

  • 如果希望调用方必须处理(比如支付接口返回“余额不足”,业务层必须做提示或跳转),就继承 Exception
  • 如果是参数校验失败、状态非法等“不该发生却发生了”的逻辑错误,就继承 RuntimeException(如 IllegalArgumentException
  • 绝对不要直接继承 Throwable —— 这等于把自己写的异常和 OutOfMemoryError 放到同一层级,语义混乱,还可能被误捕获成系统级错误

一个容易忽略的细节:自定义异常类名最好以 Exception 结尾(如 InsufficientBalanceException),这是 Java 社区约定,IDE 和静态检查工具都依赖这个命名识别异常类型。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

309

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

317

2023.10.25

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1286

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

275

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2199

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

34

2026.01.19

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

612

2023.08.10

空指针异常处理
空指针异常处理

本专题整合了空指针异常解决方法,阅读专题下面的文章了解更多详细内容。

22

2025.11.16

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

2

2026.02.06

热门下载

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

精品课程

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

共23课时 | 3.3万人学习

C# 教程
C# 教程

共94课时 | 8.7万人学习

Java 教程
Java 教程

共578课时 | 59万人学习

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

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