Java基础异常-自定义异常

简介: Java基础异常-自定义异常

Java基础异常-自定义异常

java中怎么自定义异常呢?


两步:


第一步:编写一个类继承Exception或者RuntimeException

第二步:提供两个构造方法,一个无参数的,一个带有String参数的。


示例代码01:


public class MyException extends Exception{
    public MyException(){
    }
    public MyException(String s){
        super(s);
    }
}


示例代码02


public class ExceptionTest15 {
    public static void main(String[] args) {
        //创建异常对象(这里只是new了,并没有抛出异常!)
        MyException e = new MyException("用户名不能为空!");
        //打印异常堆栈信息
        e.printStackTrace();
        //打印异常简单信息
        String m = e.getMessage();
        System.out.println(m);
    }
}


运行结果:


0a2653c851af460fa595bd959398a8f1.png


模拟栈代码异常:


Mystack.java
public class MyStack {
        // 向栈当中存储元素,我们这里使用一维数组模拟。存到栈中,就表示存储到数组中。
        // 因为数组是我们学习java的第一个容器。
        // 为什么选择Object类型数组?因为这个栈可以存储java中的任何引用类型的数据
        // new Animal()对象可以放进去,new Person()对象也可以放进去。因为Animal和Person的超级父类就是Object。
        // 包括String也可以存储进去。因为String父类也是Object。
        private Object[] elements;
        // 栈帧,永远指向栈顶部元素
        // 那么这个默认初始值应该是多少。注意:最初的栈是空的,一个元素都没有。
        //private int index = 0; // 如果index采用0,表示栈帧指向了顶部元素的上方。
        //private int index = -1; // 如果index采用-1,表示栈帧指向了顶部元素。
        private int index;
        /**
         * 无参数构造方法。默认初始化栈容量10.
         */
        public MyStack() {
            // 一维数组动态初始化
            // 默认初始化容量是10.
            this.elements = new Object[10];
            // 给index初始化
            this.index = -1;
        }
        /**
         * 压栈的方法
         * @param obj 被压入的元素
         */
        public void push(Object obj) throws MyStackOperationException {
            if(index >= elements.length - 1){
                // 改良之前
                //System.out.println("压栈失败,栈已满!");
                //return;
                // 创建异常对象
                //MyStackOperationException e = new MyStackOperationException("压栈失败,栈已满!");
                // 手动将异常抛出去!
                //throw e; //这里捕捉没有意义,自己new一个异常,自己捉,没有意义。栈已满这个信息你需要传递出去。
                //合并(手动抛出异常)
                throw new MyStackOperationException("栈已满,压栈失败!");
            }
            // 程序能够走到这里,说明栈没满
            // 向栈中加1个元素,栈帧向上移动一个位置。
            index++;
            elements[index] = obj;
            // 在声明一次:所有的System.out.println()方法执行时,如果输出引用的话,自动调用引用的toString()方法。
            System.out.println("压栈" + obj + "元素成功,栈帧指向" + index);
        }
        /**
         * 弹栈的方法,从数组中往外取元素。每取出一个元素,栈帧向下移动一位。
         * @return
         */
        public void pop() throws MyStackOperationException {
            if(index < 0){
                throw new MyStackOperationException("栈已空,弹栈失败!");
            }
            // 程序能够执行到此处说明栈没有空。
            System.out.print("弹栈" + elements[index] + "元素成功,");
            // 栈帧向下移动一位。
            index--;
            System.out.println("栈帧指向" + index);
        }
        // set和get也许用不上,但是你必须写上,这是规矩。你使用IDEA生成就行了。
        // 封装:第一步:属性私有化,第二步:对外提供set和get方法。
        public Object[] getElements() {
            return elements;
        }
        public void setElements(Object[] elements) {
            this.elements = elements;
        }
        public int getIndex() {
            return index;
        }
        public void setIndex(int index) {
            this.index = index;
        }
    }


MyStackOperationException.java


/**
 * 栈操作异常:自定义异常!
 */
public class MyStackOperationException extends Exception{//编译时异常
    public MyStackOperationException(){
    }
    public MyStackOperationException(String s){
        super(s);
    }
}


ExceptionTest16.java


public class ExceptionTest16 {
    public static void main(String[] args) {
        //创建栈对象
        MyStack Stack = new MyStack();
        try {
            Stack.push(new Object());
            Stack.push(new Object());
            Stack.push(new Object());
            Stack.push(new Object());
            Stack.push(new Object());
            Stack.push(new Object());
            Stack.push(new Object());
            Stack.push(new Object());
            Stack.push(new Object());
            Stack.push(new Object());
            //栈已满,压栈失败!
            Stack.push(new Object());
        } catch (MyStackOperationException e) {
            //打印异常简单信息
            System.out.println(e.getMessage());
        }
        try {
            Stack.pop();
            Stack.pop();
            Stack.pop();
            Stack.pop();
            Stack.pop();
            Stack.pop();
            Stack.pop();
            Stack.pop();
            Stack.pop();
            Stack.pop();
            //栈已空,弹栈失败!
            Stack.pop();
        } catch (MyStackOperationException e) {
            //打印异常简单信息
            System.out.println(e.getMessage());
        }
    }
}


运行结果:


2d65d23f6d4748949b924e4057485923.png

相关文章
|
Java
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
495 1
|
6月前
|
存储 Java 索引
用Java语言实现一个自定义的ArrayList类
自定义MyArrayList类模拟Java ArrayList核心功能,支持泛型、动态扩容(1.5倍)、增删改查及越界检查,底层用Object数组实现,适合学习动态数组原理。
266 4
|
8月前
|
Java 数据库 C++
Java异常处理机制:try-catch、throws与自定义异常
本文深入解析Java异常处理机制,涵盖异常分类、try-catch-finally使用、throw与throws区别、自定义异常及最佳实践,助你写出更健壮、清晰的代码,提升Java编程能力。
|
Java API 调度
如何避免 Java 中的 TimeoutException 异常
在Java中,`TimeoutException`通常发生在执行操作超过预设时间时。要避免此异常,可以优化代码逻辑,减少不必要的等待;合理设置超时时间,确保其足够完成正常操作;使用异步处理或线程池管理任务,提高程序响应性。
627 13
|
Java
在 Java 中,如何自定义`NumberFormatException`异常
在Java中,自定义`NumberFormatException`异常可以通过继承`IllegalArgumentException`类并重写其构造方法来实现。自定义异常类可以添加额外的错误信息或行为,以便更精确地处理特定的数字格式转换错误。
289 1
|
10月前
|
Java 程序员 数据库连接
我们详细地讲解一下 Java 异常及要如何处理
我是小假 期待与你的下一次相遇 ~
223 1
|
9月前
|
XML 人工智能 Java
java通过自定义TraceId实现简单的链路追踪
本文介绍了如何在Spring Boot项目中通过SLF4J的MDC实现日志上下文traceId追踪。内容涵盖依赖配置、拦截器实现、网关与服务间调用的traceId传递、多线程环境下的上下文同步,以及logback日志格式配置。适用于小型微服务架构的链路追踪,便于排查复杂调用场景中的问题。
432 0
|
SQL Java 中间件
【YashanDB知识库】yasdb jdbc驱动集成BeetISQL中间件,业务(java)报autoAssignKey failure异常
在BeetISQL 2.13.8版本中,客户使用batch insert向yashandb表插入数据并尝试获取自动生成的sequence id时,出现类型转换异常。原因是beetlsql在prepareStatement时未指定返回列,导致yashan JDBC驱动返回rowid(字符串),与Java Bean中的数字类型tid不匹配。此问题影响业务流程,使无法正确获取sequence id。解决方法包括:1) 在batchInsert时不返回自动生成的sequence id;2) 升级至BeetISQL 3,其已修正该问题。
【YashanDB知识库】yasdb jdbc驱动集成BeetISQL中间件,业务(java)报autoAssignKey failure异常
|
SQL druid Oracle
【YashanDB知识库】yasdb jdbc驱动集成druid连接池,业务(java)日志中有token IDENTIFIER start异常
客户Java日志中出现异常,影响Druid的merge SQL功能(将SQL字面量替换为绑定变量以统计性能),但不影响正常业务流程。原因是Druid在merge SQL时传入null作为dbType,导致无法解析递归查询中的`start`关键字。
|
Java 程序员 开发者
Java社招面试题:一个线程运行时发生异常会怎样?
大家好,我是小米。今天分享一个经典的 Java 面试题:线程运行时发生异常,程序会怎样处理?此问题考察 Java 线程和异常处理机制的理解。线程发生异常,默认会导致线程终止,但可以通过 try-catch 捕获并处理,避免影响其他线程。未捕获的异常可通过 Thread.UncaughtExceptionHandler 处理。线程池中的异常会被自动处理,不影响任务执行。希望这篇文章能帮助你深入理解 Java 线程异常处理机制,为面试做好准备。如果你觉得有帮助,欢迎收藏、转发!
774 14
下一篇
开通oss服务