Java业务异常与系统异常如何区分
时间:2026-01-05 13:07:49 233浏览 收藏
从现在开始,我们要努力学习啦!今天我给大家带来《Java业务异常与系统异常怎么区分》,感兴趣的朋友请继续看下去吧!下文中的内容我们主要会涉及到等等知识点,如果在阅读本文过程中有遇到不清楚的地方,欢迎留言呀!我们一起讨论,一起学习!
业务异常是设计好的可预期失败,如OrderNotFoundException;系统异常是需修复的程序缺陷,如空指针。二者须严格区分处理:业务异常继承RuntimeException并全局捕获返回400,系统异常记录告警返回500。

业务异常是“规则不满足”,系统异常是“程序崩了”
业务异常是你设计好的、可预期的失败场景,比如 OrderNotFoundException、InsufficientBalanceException;它不表示代码写错了,而是用户操作或数据状态触发了业务约束。系统异常则是程序本身出了问题:空指针、数组越界、数据库连接断开、JVM 内存溢出(OutOfMemoryError)——这些不是你“想让它发生”的,而是必须修复的缺陷。
关键区别在于:业务异常该被 捕获并友好反馈,系统异常该被 记录、告警、隔离甚至熔断。混淆二者会导致两种后果:把空指针当业务异常吞掉(掩盖 bug),或把余额不足当成系统错误重试三次(引发重复扣款)。
用继承关系明确分层:业务异常继承 RuntimeException
Spring 默认只对 RuntimeException 及其子类回滚事务,而业务异常本就不该让调用方强制 try-catch(否则 Controller 层会堆满冗余逻辑)。所以标准做法是:
- 自定义
BusinessException继承RuntimeException,带code和message字段 - 系统异常保留原始类型:如
SQLException、TimeoutException、NullPointerException - 数据访问层(DAO)捕获
SQLException后,不直接抛给上层,而是转为更语义化的业务异常或封装为系统异常(如DataAccessException)
public class BusinessException extends RuntimeException {
private final String code;
public BusinessException(String code, String message) {
super(message);
this.code = code;
}
public String getCode() { return code; }
}
@ControllerAdvice 里按类型分流处理
全局异常处理器不是“兜底大杂烩”,而是要严格区分流向:
@ExceptionHandler(BusinessException.class)→ 记WARN日志,返回400 Bad Request+ 统一响应体(含code和提示文案)@ExceptionHandler(Exception.class)→ 记ERROR日志(带完整堆栈),返回500 Internal Server Error,且 绝不暴露数据库表名、SQL 或路径信息- 特别注意:不要用
catch (Exception e)包住整个 service 方法——这会让事务失效,且掩盖真实异常类型
分布式调用中,异常必须可序列化且带上下文
微服务之间传异常,不能靠 JVM 堆栈——跨进程后就丢了。Resilience4j、Feign、Dubbo 等框架都依赖异常的序列化能力:
- 自定义业务异常必须实现
Serializable - 系统异常如
TimeoutException虽可序列化,但建议在 RPC 客户端统一包装成RemoteCallException(code="RPC_TIMEOUT", message="调用下游超时") - 日志中务必补全 traceId、userId、method、params —— 没有上下文的
BusinessException("库存不足")在线上等于没日志
最容易被忽略的是:本地抛出的 BusinessException 到了下游服务,可能变成 RuntimeException 被重新包装。这时需在网关或 RPC 框架层约定统一错误码协议,而不是靠异常类名判断类型。
到这里,我们也就讲完了《Java业务异常与系统异常如何区分》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
444 收藏
-
474 收藏
-
172 收藏
-
292 收藏
-
272 收藏
-
130 收藏
-
161 收藏
-
180 收藏
-
275 收藏
-
403 收藏
-
409 收藏
-
315 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习