使用自定义异常可明确表达业务错误,如“订单已过期”,通过继承RuntimeException并添加错误码,在支付场景中抛出OrderException,结合@ControllerAdvice统一返回结构化错误信息,提升系统可维护性和前后端协作效率。

在Java开发中,自定义异常不仅能提升代码的可读性和健壮性,还能与业务逻辑紧密结合,使程序在面对特定错误场景时具备更清晰的处理路径。通过将异常设计融入业务流程,开发者可以快速定位问题、统一错误响应,并增强系统的可维护性。
Java内置的异常类型(如IllegalArgumentException、RuntimeException)虽然覆盖常见错误,但难以表达具体业务含义。例如,“用户余额不足”或“订单已过期”这类问题,用通用异常无法直观体现错误本质。
自定义异常的优势包括:
通常继承RuntimeException(非检查异常)以避免强制try-catch,同时可根据需要添加构造方法和字段。
立即学习“Java免费学习笔记(深入)”;
示例:定义一个订单相关的异常public class OrderException extends RuntimeException {
private String errorCode;
public OrderException(String message, String errorCode) {
super(message);
this.errorCode = errorCode;
}
public String getErrorCode() {
return errorCode;
}
}这样在抛出异常时,既能传递可读信息,也能保留系统识别用的错误码,便于前端或日志分析。
将自定义异常嵌入服务层,能有效解耦校验逻辑与主流程。比如订单支付场景:
public void payOrder(Long orderId, BigDecimal amount) {
Order order = orderRepository.findById(orderId);
if (order == null) {
throw new OrderException("订单不存在", "ORDER_NOT_FOUND");
}
if (order.getStatus() == OrderStatus.PAID) {
throw new OrderException("订单已支付", "ORDER_ALREADY_PAID");
}
if (order.getAmount().compareTo(amount) != 0) {
throw new OrderException("支付金额不匹配", "AMOUNT_MISMATCH");
}
// 执行支付逻辑
}调用方无需层层判断返回值,只需关注是否成功,失败则由统一异常处理器拦截并返回结构化结果。
在Spring Boot项目中,使用@ControllerAdvice捕获自定义异常,返回标准格式的错误信息。
@ControllerAdvice
public class GlobalExceptionHandler {
@ResponseBody
@ExceptionHandler(OrderException.class)
public ResponseEntity<Map<String, Object>> handleOrderException(OrderException e) {
Map<String, Object> response = new HashMap<>();
response.put("success", false);
response.put("message", e.getMessage());
response.put("errorCode", e.getErrorCode());
return ResponseEntity.status(400).body(response);
}
}这样前端收到的每次业务异常都具有一致的数据结构,降低处理复杂度。
基本上就这些。把异常当成业务语义的一部分来设计,而不是仅仅作为错误标志,能让系统更清晰、更易维护。关键是在团队内达成一致,规范异常的命名、分类和使用方式。
以上就是Java中自定义异常与业务逻辑结合的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号