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

相关文章
|
4天前
|
Java
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
|
4天前
|
Java
在 Java 中,如何自定义`NumberFormatException`异常
在Java中,自定义`NumberFormatException`异常可以通过继承`IllegalArgumentException`类并重写其构造方法来实现。自定义异常类可以添加额外的错误信息或行为,以便更精确地处理特定的数字格式转换错误。
|
5天前
|
IDE 前端开发 Java
怎样避免 Java 中的 NoSuchFieldError 异常
在Java中避免NoSuchFieldError异常的关键在于确保类路径下没有不同版本的类文件冲突,避免反射时使用不存在的字段,以及确保所有依赖库版本兼容。编译和运行时使用的类版本应保持一致。
|
6天前
|
Java 编译器
如何避免在 Java 中出现 NoSuchElementException 异常
在Java中,`NoSuchElementException`通常发生在使用迭代器、枚举或流等遍历集合时,尝试访问不存在的元素。为了避免该异常,可以在访问前检查是否有下一个元素(如使用`hasNext()`方法),或者使用`Optional`类处理可能为空的情况。正确管理集合边界和条件判断是关键。
|
9天前
|
Java
Java异常捕捉处理和错误处理
Java异常捕捉处理和错误处理
11 1
|
19天前
|
Java 开发者 Spring
[Java]自定义注解
本文介绍了Java中的四个元注解(@Target、@Retention、@Documented、@Inherited)及其使用方法,并详细讲解了自定义注解的定义和使用细节。文章还提到了Spring框架中的@AliasFor注解,通过示例帮助读者更好地理解和应用这些注解。文中强调了注解的生命周期、继承性和文档化特性,适合初学者和进阶开发者参考。
42 14
|
11天前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
26 2
|
17天前
|
Java
如何在 Java 中处理“Broken Pipe”异常
在Java中处理“Broken Pipe”异常,通常发生在网络通信中,如Socket编程时。该异常表示写入操作的另一端已关闭连接。解决方法包括:检查网络连接、设置超时、使用try-catch捕获异常并进行重试或关闭资源。
|
20天前
|
存储 安全 Java
如何避免 Java 中的“ArrayStoreException”异常
在Java中,ArrayStoreException异常通常发生在尝试将不兼容的对象存储到泛型数组中时。为了避免这种异常,确保在操作数组时遵循以下几点:1. 使用泛型确保类型安全;2. 避免生类型(raw types)的使用;3. 在添加元素前进行类型检查。通过这些方法,可以有效防止 ArrayStoreException 的发生。
|
21天前
|
人工智能 Oracle Java
解决 Java 打印日志吞异常堆栈的问题
前几天有同学找我查一个空指针问题,Java 打印日志时,异常堆栈信息被吞了,导致定位不到出问题的地方。
30 2