异常处理(6)自定义异常

异常处理(6)自定义异常类

1、自定义异常要求:

(1)要继承一个异常类型

自定义一个编译时异常类型:自定义类继承java.lang.Exception

自定义一个运行时异常类型:自定义类继承java.lang.RuntimeException

(2)建议大家提供至少两个构造器,一个是无参构造,一个是(String message)构造器。

(3)自定义异常需要提供serialVersionUID

自定义异常类的使用:

  1. 自定义异常最重要的是异常类的名字和message属性。当异常出现时,可以根据名字判断异常类型。比如:TeamException("成员已满,无法添加");
  2. 自定义异常对象只能手动抛出。抛出后由try-catch处理,也可以用throws给调用者处理。

例如:

java 复制代码
public class MyException extends RuntimeException{
    public MyException() {
    }

    public MyException(String message) {
        super(message);
    }
}
public class Person {
    private String name;
    private int lifeValue;

    public Person() {
    }

    public Person(String name, int lifeValue) {
        this.name = name;
        setLifeValue(lifeValue);
    }

    public String getName() {
        return name;
    }

    public int getLifeValue() {
        return lifeValue;
    }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", lifeValue=" + lifeValue +
                '}';
    }

    public void setLifeValue(int lifeValue) {
        if(lifeValue>=0)
        this.lifeValue = lifeValue;
        else {
            throw new MyException("This lifeValue couldn't be negative."+lifeValue);
        }
    }

    public static void main(String[] args) {
        Person p1 = new Person("Qum",18);
        System.out.println(p1.toString());
        Person p2 = new Person("Dit",-19999);
        System.out.println(p2.toString());
    }
}
相关推荐
惊鸿若梦一书生7 分钟前
《Python 高阶教程》003|变量背后不是盒子:名字、对象与引用的本质
java·jvm·python
gelald21 分钟前
SpringBoot - Actuator与监控
java·spring boot·后端
深紫色的三北六号21 分钟前
仿大疆司空2面状航线生成——凸多边形区域航线生成算法详解
java·算法·无人机·大疆·航线规划
电商API&Tina1 小时前
1688 拍立淘接口(item_search_img)测试与接入实战心得
java·大数据·前端·物联网·oracle·json
行走的搬运工1 小时前
Spring Security_05
java·spring·mybatis
我登哥MVP1 小时前
【Spring6笔记】 - 11 - JDBCTemplate
java·数据库·spring boot·mysql·spring
也许明天y1 小时前
Spring AI 核心原理解析:基于 1.1.4 版本拆解底层架构
java·后端·spring
小红的布丁1 小时前
BIO、NIO、AIO 与 IO 多路复用:select、poll、epoll 详解
java·数据库·nio
lifallen1 小时前
Flink Checkpoint 流程、Barrier 流动与 RocksDB 排障
java·大数据·flink
疯狂打码的少年1 小时前
【Day12 Java转Python】Python工程的“骨架”——模块、包与__name__
java·开发语言·python