异常处理通过抛出、传播和捕获实现:JVM或throw抛出异常,沿调用栈向上传播,由try-catch-finally捕获处理,受检异常需显式处理或声明,非受检异常可不处理,finally用于资源释放。

Java异常处理机制通过抛出、传播和捕获三个核心环节来管理程序运行中的错误。当代码出现异常情况(如数组越界、空指针、文件未找到等),JVM会创建一个异常对象并将其抛出。这个异常对象沿着调用栈向上传播,直到被合适的catch块捕获处理,否则程序将终止。
异常的产生与抛出
异常通常由以下两种方式触发:
- 系统自动抛出:运行时检测到错误,如NullPointerException、ArrayIndexOutOfBoundsException,JVM自动生成并抛出异常。
- 手动抛出:开发者使用throw关键字主动抛出异常,常用于业务逻辑校验失败时。
例如:
if (user == null) {
throw new IllegalArgumentException("用户对象不能为空");
}
异常的传播机制
异常一旦被抛出,就会从当前方法沿调用栈向上“冒泡”,直到被处理为止。JVM会逐层检查每个方法是否包含能处理该异常的try-catch结构。
立即学习“Java免费学习笔记(深入)”;
- 如果当前方法没有try-catch或catch无法匹配该异常类型,异常继续向调用者方法传递。
- 若一直传播到main方法仍未被捕获,JVM将终止程序,并打印异常堆栈信息。
例如:
void methodA() {
methodB();
}
void methodB() {
methodC();
}
void methodC() {
throw new RuntimeException("出错了");
}
此时异常从methodC → methodB → methodA → main层层上抛,最终导致程序中断。
异常的捕获与处理
使用try-catch-finally结构可以捕获并处理异常,防止程序崩溃。
- try块:包裹可能出错的代码。
- catch块:按异常类型捕获并处理,多个catch需从子类到父类排列。
- finally块:无论是否发生异常都会执行,常用于资源释放(如关闭文件、数据库连接)。
示例:
try {
int result = 10 / 0;
} catch (ArithmeticException e) {
System.out.println("捕获除零异常:" + e.getMessage());
} finally {
System.out.println("清理资源");
}
异常分类与throws声明
Java异常分为两类:
- 受检异常(Checked Exception):如IOException,编译器强制要求处理或声明,必须用try-catch捕获或通过throws向上抛出。
- 非受检异常(Unchecked Exception):包括运行时异常(RuntimeException)和错误(Error),不要求强制处理。
若方法不打算处理受检异常,可通过throws将责任转交给调用者:
void readFile() throws IOException {
// 可能抛出IOException
}
基本上就这些。理解异常的传播路径和捕获时机,能帮助写出更健壮的Java程序。关键是合理使用try-catch,避免吞掉异常,同时确保资源正确释放。不复杂但容易忽略细节。










