一、为什么要自定义异常类
1、为什么要自定义异常类
Java中不同的异常类,分别表示着某一种具体的异常情况,那么在开发中总是有些异常情况是没有定义好的,此时我们根据自己业务的异常情况来定义异常类。
一些异常都是 Java 内部定义好的,但是实际开发中也会出现很多异常,这些异常很可能在JDK中没有定义过,例如年龄负数问题,考试成绩负数问题,这时就需要我们自定义异常。
2、什么是自定义异常类
在开发中根据自己业务的异常情况来定义异常类。
二、异常类如何自定义
1、如何自定义
① 一般地,用户自定义异常类都是 RuntimeException 的子类;
② 自定义异常类通常需要编写几个重载的构造器;
③ 自定义异常需要提供 serialVersionID;
④ 自定义的异常通过 throw 抛出;
⑤ 自定义异常最重要的是异常类的名字,当异常出现时,可以根据名字判断异常类型;
2、案例
(1)自定义一个编译器异常:自定义类 并继承 java.lang.Exception
(2)自定义一个运行时期的异常类:自定义类,并继承于 java.lang.RuntimeException。
建议:保留两种构造器的形式
①无参构造
②带给父类的message属性赋值的构造器
语法格式:
public class XXXExcepiton extends Exception | RuntimeException{
添加一个空参数的构造方法
添加一个带异常信息的构造方法
}
注意:
(1)自定义异常类一般都是以Exception结尾,说明该类是一个异常类
(2)自定义异常类,必须的继承Exception或者RuntimeException
继承Exception:那么自定义的异常类就是一个编译期异常,如果方法内部抛出了编译期异常,就必须处理这个异常,要么throws,要么try...catch
继承RuntimeException:那么自定义的异常类就是一个运行期异常,无需处理,交给虚拟机处理(中断处理)
Demo:
1 public class DemoRegisterException {
2 // 1.使用数组保存已经注册过的用户名(数据库)
3 static String[] usernames = {"张三","李四","王五"};
4
5 public static void main(String[] args) /*throws RegisterException*/ {
6 //2.使用Scanner获取用户输入的注册的用户名(前端,页面)
7 Scanner sc = new Scanner(System.in);
8 System.out.println("请输入您要注册的用户名:");
9 String username = sc.next();
10 checkUsername(username);
11
12 }
13
14 //3.定义一个方法,对用户输入的中注册的用户名进行判断
15 public static void checkUsername(String username) /*throws RegisterException*/ {
16 //遍历存储已经注册过用户名的数组,获取每一个用户名
17 for (String name : usernames) {
18 //使用获取到的用户名和用户输入的用户名比较
19 if(name.equals(username)){
20 //true:用户名已经存在,抛出RegisterException异常,告知用户"亲,该用户名已经被注册";
21 try {
22 throw new RegisterException("亲,该用户名已经被注册");
23 } catch (RegisterException e) {
24 e.printStackTrace();
25 return; //结束方法
26 }
27 }
28 }
29
30 //如果循环结束了,还没有找到重复的用户名,提示用户"恭喜您,注册成功!";
31 System.out.println("恭喜您,注册成功!");
32 }
33 }
34
35 // 异常类
36 public class RegisterException extends /*Exception*/ RuntimeException{
37 //添加一个空参数的构造方法
38 public RegisterException(){
39 super();
40 }
41
42 /*
43 添加一个带异常信息的构造方法
44 查看源码发现,所有的异常类都会有一个带异常信息的构造方法,方法内部会调用父类带异常信息的构造方法,让父类来处理这个异常信息
45 */
46 public RegisterException(String message){
47 super(message);
48 }
49 }