0

0

在Java里Exception和Error有何区别_Java异常体系说明

P粉602998670

P粉602998670

发布时间:2026-02-10 01:21:19

|

470人浏览过

|

来源于php中文网

原创

应捕获Exception而非Error:前者可恢复(如IO异常),后者表JVM崩溃(如OOM),捕获Error会导致数据错乱;Checked异常强制处理,Unchecked异常暴露逻辑缺陷;自定义异常禁继承Error。

在java里exception和error有何区别_java异常体系说明

Exception 是程序能干预的意外,Error 是 JVM 自己扛不住了

直接说结论:你该捕获 Exception,但绝不该捕获 Error。因为前者代表“这事我能救”,比如文件没找到、网络超时、数组越界;后者代表“地基塌了”,比如 OutOfMemoryErrorStackOverflowErrorNoClassDefFoundError——JVM 已无法保证后续行为正确,强行 catch 后继续执行,大概率引发数据错乱或静默失败。

为什么不能写 catch(Error e) 来“兜底”

这不是语法错误,而是设计反模式。真实项目里见过有人在全局异常处理器里加 catch(Throwable t),本意是“防崩”,结果把 OutOfMemoryError 也吞了,日志只打一行“捕获到 Throwable”,内存持续泄漏却毫无感知。

  • Error 不是设计给业务代码处理的,它不提供恢复语义,JVM 在抛出后通常已进入不可信状态
  • 捕获 Error 后调用 e.printStackTrace() 或记录日志,对排障几乎无用——真正要的是 JVM 堆转储(heap dump)、GC 日志、启动参数分析
  • 若真想监控,应通过 Thread.setUncaughtExceptionHandler 捕获未处理的 Error,仅用于告警和进程优雅退出,而非“继续跑业务”

Exception 分两类,编译器管不管,决定了你能不能“偷懒”

Java 强制你面对一部分异常,不是为了为难你,而是提醒:“这事儿外部环境说了算,你得提前想好 Plan B”。

  • 检查型异常(Checked Exception):如 IOExceptionSQLException。方法签名里写了 throws,你就必须 try-catch 或向上声明——否则编译失败
  • 非检查型异常(Unchecked Exception):即 RuntimeException 及其子类,如 NullPointerExceptionIllegalArgumentException。编译器放行,但不等于可以忽略;它们往往暴露逻辑缺陷,比如没校验入参就调用 .length()

注意:自定义异常务必继承 Exception(需检查)或 RuntimeException(不需检查),永远不要继承 Error——那等于告诉所有人“我这个异常是 JVM 级灾难”。

MeDo
MeDo

无代码AI应用开发,百度秒哒海外版

下载

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

容易被忽略的实战细节

很多问题不是出在“会不会写 try-catch”,而是出在边界认知模糊:

  • ClassNotFoundExceptionException,但运行时几乎无法恢复(类路径缺失),实际应归为“启动失败”,不该靠 catch 重试,而应检查打包、依赖、ClassLoader 层级
  • AssertionErrorError 子类,但它由 assert 触发,属于开发期断言——上线时通常禁用,捕获它毫无意义
  • Spring 等框架会把底层 Error 包装成 RuntimeException 抛出(如 BeanCreationException),这时你看到的是 Exception,但根因可能是 NoClassDefFoundError,得看 getCause()

真正关键的,从来不是“怎么 catch”,而是“这个异常到底意味着什么系统状态”——Exception 要问“怎么恢复”,Error 要问“为什么发生”。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

118

2025.08.06

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

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

75

2026.01.26

scripterror怎么解决
scripterror怎么解决

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

331

2023.10.18

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

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

325

2023.10.25

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

406

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

585

2023.08.10

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

936

2023.09.19

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

91

2025.12.01

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

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

132

2026.02.06

热门下载

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

精品课程

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

共23课时 | 3.4万人学习

C# 教程
C# 教程

共94课时 | 9万人学习

Java 教程
Java 教程

共578课时 | 62.2万人学习

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

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