【前端学java】Java中的异常处理(15)

往期回顾:

常见的错误类型

编译时错误

这类错误在代码编写阶段产生,主要包括语法错误、类型错误、变量未声明等。这类错误在程序编译时就会被检测出来,如下面代码的类型转换错误

错误(Errors)

通常是Java虚拟机无法恢复的严重问题,如OutOfMemoryError、StackOverflowError等。如下图递归没有跳出逻辑导致的StackOverflowError报错

异常

运行时异常RuntimeException

这是未经检查的异常,Java编译器不会强制要求程序员处理这些异常(运行代码时才会出现异常提示)。

在上面的例子中,我们创建了一个包含3个元素的整数数组,然后尝试访问数组的第4个元素。由于数组长度只有3,所以这会抛出一个ArrayIndexOutOfBoundsException运行时异常。

检查型异常Checked Exceptions

这是受检查的异常,Java编译器会强制要求程序员处理这些异常。

在上面的代码中,我们尝试打开一个名为"example.txt"的文件并读取它。由于这个文件可能不存在或无法读取,因此new FileReader报错,程序无法执行。

这个时候需要通过try catch捕获异常,和前端一样

异常处理的基本语法

前端中的异常处理方法

前端中异常处理基本上使用try-catch 语句就够了,Promise 链式调用中使用.catch 方法也可以捕获异常,这两种是常用的,都很简单。

后端中的异常处理方法

Java中的异常处理语法主要包括try-catch语句和throw语句。

try-catch语句

java 复制代码
public static void main(String[] args) {  
    try {  
        String str = "Hello World";  
        int length = Integer.parseInt(str); // 传递了一个字符串类型的参数,应该使用String.length()方法获取长度  
    } catch (NumberFormatException e) {  
        // 如果传递的参数不是一个有效的整数,则会抛出NumberFormatException异常  
    } catch (IllegalArgumentException e) {  
        // 如果传递了一个不合法或不适当的参数,则会抛出IllegalArgumentException异常  
    }  finally {  
        // 无论是否发生异常,都将执行的代码块  
    }
} 

注:这里我们只做简单的语法使用展示,具体catch中的错误类型我们不必纠结深入学习,遇到具体的问题时巩固学习即可。

throw语句

throw语句用于手动抛出异常。当程序遇到一个异常条件时,可以使用throw语句抛出一个异常对象。

java 复制代码
public class Main {  
    public static void main(String[] args) {  
        int[] numbers = {2, 4, 6, 8};  
  
        // 遍历数组并查找元素  
        for (int i = 0; i < numbers.length; i++) {  
            if (numbers[i] == 5) {  
                // 手动抛出异常  
                throw new IllegalArgumentException("数组中不存在元素 5");  
            }  
        }  
    }  
}

自定义异常

在Java中,我们可以创建自定义异常,自定义异常通常从Exception或其子类派生(简单了解即可)。

java 复制代码
// 定义一个新的异常类,继承自Exception类  
public class MyException extends Exception {  
    public MyException() {  
        super();  
    }  
  
    public MyException(String message) {  
        super(message);  
    }  
  
    public MyException(String message, Throwable cause) {  
        super(message, cause);  
    }  
  
    public MyException(Throwable cause) {  
        super(cause);  
    }  
}

现在,我们可以在代码中抛出这个新的异常:

java 复制代码
public class Test {  
    public static void main(String[] args) {  
        try {  
            // 在这里抛出我们的自定义异常  
            throw new MyException("这是我的异常");  
        } catch (MyException e) {  
            e.printStackTrace();  
        }  
    }  
}
相关推荐
舒一笑9 分钟前
PandaCoder重大产品更新-引入Jenkinsfile文件支持
后端·程序员·intellij idea
PetterHillWater40 分钟前
AI编程之CodeBuddy的小试
后端·aigc
codervibe1 小时前
如何用 Spring Security 构建无状态权限控制系统(含角色菜单控制)
java·后端
codervibe1 小时前
项目中如何用策略模式实现多角色登录解耦?(附实战代码)
java·后端
expect7g1 小时前
Flink-Checkpoint-2.OperatorChain
后端·flink
大葱白菜1 小时前
🧱 Java 抽象类详解:从基础到实战,掌握面向对象设计的核心基石
后端·程序员
SimonKing1 小时前
颠覆传统IO:零拷贝技术如何重塑Java高性能编程?
java·后端·程序员
mCell2 小时前
为什么我们需要 `.proto` 文件
后端·微服务·架构
mit6.8242 小时前
[Meetily后端框架] AI摘要结构化 | `SummaryResponse`模型 | Pydantic库 | vs marshmallow库
c++·人工智能·后端
陈随易2 小时前
VSCode v1.102发布,AI体验大幅提升
前端·后端·程序员