Java异常处理机制

简介: Java异常处理机制一. 异常类型Exception  Exception主要分为两种:Runtime Exception、Checked(Compile) Exception。  常见的Runtime Exception,有:NullPointerException、ArithmeticException.

Java异常处理机制
一. 异常类型

  1. Exception
      Exception主要分为两种:Runtime Exception、Checked(Compile) Exception。

  常见的Runtime Exception,有:NullPointerException、ArithmeticException...

  常见的Checked(Compile) Exception,有:IOException、FileNotFoundException...

  所谓Checked Exception就是在编译期间,你必须对某条、或多条语句进行异常处理,如: try...catch...、throws语句。

  下面介绍下Checked Exception的优缺点:

特点与优点: Java专有,体现Java的设计哲学,没有完善错误处理的代码根本就不会给你机会去执行。
缺点:
必须显式捕捉并处理异常,或显式声明抛出异常,增加程序复杂度。
若显式抛出异常,则会增加方法签名与异常的耦合度。

  1. Error
      Error主要表示一些虚拟机内部错误,如:动态链接失败。

二. 异常处理规则
程序可读性:避免过度使用异常处理代码,减少方法签名与异常的耦合度。
异常原始性:捕获并保留原始异常信息。
异常针对性:根据业务需求决定如何处理异常,比如:
当你检查商品库存时发生异常,此时就应终止此次调用,并告诉上层用户详细、明确的原因。
当你获取用户头像失败时,因为该操作不影响整体订单、支付流程,所以不需要终止此次调用,可与上层用户协商处理,比如:返回一个空字符串。
三. 相关问题
throw与throws区别?
位置:
throws位于方法签名。
throw位于函数体内。
语法格式
throws后面跟的是异常类,且一次可以跟多个,只需要以逗号分隔。
throw后面跟着的是异常实例,且一次只能跟一个。
命中率
throws只是做个防守,并不会真正执行。
一旦执行到throw语句,必定抛出异常。

为什么要有异常处理机制?
无法穷举所有的异常情况。
若异常处理的代码过多,会导致程序可读性变差。

为什么要把原始异常封装一层?
安全性,防止恶意用户获得系统内部信息。
对上层用户更加友好,让其更加明确、详细的知道异常原因。

为什么有那么多类需要实现Closeable或AutoCloseable接口?
Java9增强了自动关闭资源的try语句。
复制代码
public class ExceptionTest {

public static void readFile(){
    try(BufferedReader bufferedReader = new BufferedReader(new FileReader("justForTest.txt")))
    {
        System.out.println(bufferedReader.readLine());
    } catch (IOException e) {
        e.printStackTrace();
    }
}

}

@Test
public void readFileTest(){

ExceptionTest.readFile(); // Just for test.

}
复制代码

四. 实践(自定义RuntimeException)

复制代码
@Getter
public class ServiceException extends RuntimeException {

private HttpStatus status;
private ResultCode resultCode;
private Object     errorData;

private ServiceException(HttpStatus status, ResultCode resultCode, Object errorData){
    this.status     = status;
    this.resultCode = resultCode;
    this.errorData  = errorData;
}

public static ServiceException badRequest(ResultCode resultCode, Object errorData){
    return new ServiceException(HttpStatus.BAD_REQUEST, resultCode, errorData);
}

}

@Getter
public enum ResultCode {

// errorCode
SUCCESS(0, "SUCCESS"),
INVALID_PARAMETER(600, "invalid parameter");

private final int errorCode;
private final String errorData;

ResultCode(int errorCode, String errorData){
    this.errorCode = errorCode;
    this.errorData = errorData;
}

}

@ControllerAdvice
public class GlobalErrorHandler {

@ExceptionHandler(ServiceException.class)
public ResponseEntity<ErrorResponse> handleServiceException(ServiceException ex){
    return ResponseEntity
            .status(ex.getStatus())
            .body(ErrorResponse.failed(ex.getResultCode(), ex.getErrorData()));
}

}

@ApiModel
@Getter
public class ErrorResponse implements Serializable {

private static final long serialVersionUID = -2254339918462802230L;

private final int errorCode;
private final String errorMsg;
private final T errorData;

private ErrorResponse(ResultCode resultCode, T errorData) {
    this.errorCode = resultCode.getErrorCode();
    this.errorMsg  = resultCode.getErrorData();
    this.errorData = errorData;
}

public static <T> ErrorResponse<T> failed(ResultCode resultCode, T data){
    return new ErrorResponse(resultCode, data);
}

}

@RestController
public class OrderController {

@GetMapping(value = "/v1/orders/{order_id}"/*, produces = {"application/toString", "application/json"}*/)
public Order getOrder(@PathVariable("order_id") @NotBlank String orderId){

    Order order = new Order();
    BigDecimal total = new BigDecimal(-1.00, new MathContext(2, RoundingMode.HALF_UP));

    if (total.compareTo(BigDecimal.ZERO) <= 0){
        throw ServiceException.badRequest(ResultCode.INVALID_PARAMETER,
                "Total is less than zero!");
    }
    order.setOrderId(orderId);
    order.setTotal(total);
    return order;
}

}
复制代码

五. 参考
疯狂Java讲义(第十章 - 异常处理)
JAVA核心知识点整理
原文地址https://www.cnblogs.com/YaoFrankie/p/11440626.html

相关文章
|
9天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
33 2
|
14天前
|
Java 编译器
探索Java中的异常处理机制
【10月更文挑战第35天】在Java的世界中,异常是程序运行过程中不可避免的一部分。本文将通过通俗易懂的语言和生动的比喻,带你了解Java中的异常处理机制,包括异常的类型、如何捕获和处理异常,以及如何在代码中有效地利用异常处理来提升程序的健壮性。让我们一起走进Java的异常世界,学习如何优雅地面对和解决问题吧!
|
2天前
|
安全 Java 程序员
Java中的异常处理:从新手到专家
在Java编程的世界里,异常处理是每个开发者必须面对的挑战。本文将带你从基础的异常概念出发,逐步深入到高级处理技巧,让你在遇到代码中的“意外”时,能够从容应对,甚至化险为夷。
|
7天前
|
Java 数据库连接 开发者
Java中的异常处理:从基础到高级
【10月更文挑战第42天】在Java的世界中,异常处理是维护程序稳定性和健壮性的关键。本文将带你深入了解Java的异常处理机制,从基本的try-catch语句出发,逐步探索更复杂的异常处理策略。我们将通过实际代码示例来演示如何捕获和处理异常,以及如何自定义异常类型来满足特定需求。无论你是Java新手还是有经验的开发者,这篇文章都将帮助你更好地理解和应用Java的异常处理。
|
13天前
|
Java 开发者
Java中的异常处理:从基础到高级
【10月更文挑战第35天】在Java的世界里,异常处理是维护程序健壮性的关键。本文将深入浅出地探讨Java的异常处理机制,从基本的try-catch语句到自定义异常类的实现,带领读者理解并掌握如何在Java中优雅地处理错误和异常。我们将通过实际代码示例,展示如何捕获、处理以及预防潜在的运行时错误,确保程序即使在面临意外情况时也能保持稳定运行。
31 7
|
14天前
|
Java 编译器 数据库连接
Java中的异常处理机制深度解析####
本文深入探讨了Java编程语言中异常处理机制的核心原理、类型及其最佳实践,旨在帮助开发者更好地理解和应用这一关键特性。通过实例分析,揭示了try-catch-finally结构的重要性,以及如何利用自定义异常提升代码的健壮性和可读性。文章还讨论了异常处理在大型项目中的最佳实践,为提高软件质量提供指导。 ####
|
13天前
|
Java 数据库连接 开发者
Java中的异常处理机制及其最佳实践####
在本文中,我们将探讨Java编程语言中的异常处理机制。通过深入分析try-catch语句、throws关键字以及自定义异常的创建与使用,我们旨在揭示如何有效地管理和响应程序运行中的错误和异常情况。此外,本文还将讨论一些最佳实践,以帮助开发者编写更加健壮和易于维护的代码。 ####
|
16天前
|
Java
Java 异常处理下篇:11 个异常处理最佳实践
本文深入探讨了 Java 异常处理的最佳实践,包括早抛出晚捕获、只捕获可处理的异常、不要忽略捕获的异常、抛出具体检查性异常、正确包装自定义异常、记录或抛出异常但不同时执行、避免在 `finally` 块中抛出异常、避免使用异常进行流程控制、使用模板方法处理重复的 `try-catch`、尽量只抛出与方法相关的异常以及异常处理后清理资源。通过遵循这些实践,可以提高代码的健壮性和可维护性。
|
17天前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
35 2
|
19天前
|
Java 程序员 数据库连接
深入浅出Java异常处理
【10月更文挑战第30天】在Java的世界里,异常处理就像是生活中的急救箱,遇到意外时能及时救治。本文不仅教你如何使用try-catch语句包扎“伤口”,还会深入讲解如何通过自定义异常来应对那些常见的“头疼脑热”。准备好,我们将一起探索Java异常处理的奥秘,让你的程序更加健壮。
下一篇
无影云桌面