一、异常核心体系(顶层+分类)
-
异常顶层父类: Throwable ,所有错误和异常都继承此类,核心含两个子类
-
两大核心分支(关键区分)
-
Error :系统级错误,无法通过代码处理,如内存溢出(OutOfMemoryError)、栈溢出(StackOverflowError),直接导致程序终止
-
Exception :程序级异常,可编码处理,是开发重点,分两类子异常
(1)运行时异常(非检查型):继承 RuntimeException ,编译不报错、运行时触发,如空指针(NullPointerException)、数组下标越界(ArrayIndexOutOfBoundsException)、类型转换异常
(2)编译时异常(检查型):直接继承 Exception ,编译必须处理(捕获/声明),否则报错,如IO异常(IOException)、SQL异常(SQLException)
二、异常处理 5个核心关键字(必记+用法)
-
try :监控代码块,把可能出异常的代码包裹其中,单独使用无意义,必须搭配 catch 或 finally
-
catch :捕获 try 中抛出的异常,可多个 catch 并列(子类异常在前、父类异常在后),内部写异常处理逻辑(打印/补救)
-
finally :跟在 catch 之后,无论是否触发异常都会执行,核心用途是释放资源(关闭IO流、数据库连接),唯一不执行的情况是调用 System.exit(0) 终止JVM
-
throw :写在方法内部,手动主动抛出单个异常对象(如 throw new NullPointerException("空指针异常") )
-
throws :写在方法声明后,声明该方法可能抛出的异常类型,把异常交给调用者处理,可声明多个异常,用逗号分隔
三、异常两种处理方式(开发常用)
- 捕获处理(try-catch[-finally]):自己处理异常,适合不想让异常向上传递的场景,格式:
java
try{
可能出异常的代码;
}catch(异常类型 异常名){
异常处理逻辑;
}finally{
资源释放代码;
}
- 声明抛出(throws):不处理异常,抛给上层调用者,适合需要逐层反馈异常的场景,格式: public void 方法名() throws 异常类型1,异常类型2{}
四、自定义异常(按需实现)
-
核心前提:继承 Exception (编译时异常)或 RuntimeException (运行时异常),二选一即可
-
必备步骤:重写2个构造方法(无参构造+带异常信息的有参构造),满足不同场景手动抛异常需求
-
简单示例:自定义一个登录失败异常(运行时)
java
public class LoginFailException extends RuntimeException{
public LoginFailException(){} // 无参构造
public LoginFailException(String msg){super(msg);} // 带信息构造
}
五、异常处理 3个核心注意事项
-
多个 catch 并列时,子类异常必须放在父类异常前面(否则父类会捕获所有子类异常,子类catch失效)
-
重写方法的异常规则:子类重写父类方法时,抛出的异常不能比父类方法的异常范围大(可少抛、不抛,或抛子类异常)
-
JDK7+ 简化资源关闭:用 try-with-resources 语法,将资源声明在try后的括号中,程序结束会自动关闭资源,无需写finally,适配实现 AutoCloseable 接口的类(IO流、数据库连接)
喜欢的宝宝们可以一键三连哦~爱你们!