37、Java基础之异常

异常

  • Exception(异常):
    软件程序在运行过程中遇到,用户输入不符合要求、程序要打开某的文件,不存在或者文件格式不对,读取数据库,数据为空。程序跑着,内存或硬盘满了。遇到这些文件找不到、网络连接失败、非法参数等异常问题,它影响了正常的程序执行流程。怎样才能让程序合理处理,不至于程序崩溃。

  • 异常分类
    检查性异常:用户错误或问题引起的异常,这是程序员无法预见的。例如要打开一个不存在文件时,一个异常就发生了,这些异常在编译时不能被简单地忽略。
    运行时异常::运行时异常是可能被程序员避免的异常。与检查性异常相反,运行时异常可以在编译时被忽略。

注意!

错误::错误不是异常,而是脱离程序员控制的问题。错误在代码中通常被忽略。例如,当栈溢出时,一个错误就发生了,它们在编译也检查不到的。

Error

  • Error类对象由Java虚拟机生成并抛出,大多数错误与代码编写者所执行的操作无关。
  • Java虚拟机运行错误(Virtual MachineError),当JVM不再有继续执行操作所需的内存资源时,将出现OutOfMemoryError。这些异常发生时,Java虚拟机(JVM)一般会选择线程终止;

还有发生在虚拟机试图执行应用时,如类定义错误(NoClassDefFoundError)、链接错误(LinkageError)。

这些错误是不可查的,因为它们在应用程序的控制和处理能力之外,而且绝大多数是程序运行时不允许出现的状况。

Exception

  • Exception分支中有一个重要的子类RuntimeException(运行时异常)
    1、ArrayIndexOutOfBoundsException(数组下标越界)
    2、NullPointerException(空指针异常)
    3、ArithmeticException(算术异常)
    4、MissingResourceException(丢失资源)
    5、ClassNotFoundException(找不到类)等异常,
    这些异常是不检查异常,程序中可以选择捕获处理,也可以不处理。

  • 这些异常一般是由程序逻辑错误引起的,程序应该从逻辑角度尽可能避免这类异常的发生;

  • Error和Exception的区别:
    1、Error通常是灾难性的致命的错误,是程序无法控制和处理的,当出现这些异常时,Java虚拟机(JVM)一般会选择终止线程;
    2、Exception通常情况下是可以被程序处理的,并且在程序中应该尽可能的去处理这些异常。

在这里插入图片描述

  • 自定义异常
    除了使用Java内置的异常类,还可以自定义异常,只需继承Exception类即可。

  • 在程序中使用自定义异常类,大体可分为以下几个步骤:
    1.创建自定义异常类。
    2.在方法中通过throw关键字抛出异常对象。
    3.如果在当前抛出异常的方法中处理异常,可以使用try-catch语句捕获并处理;否则在方法的声明处通过throws关键字指明要抛出给方法调用者的异常,继续进行下一步操作。
    4.在出现异常方法的调用者中捕获并处理异常。

  • 自定义异常实例
    MyException自定义异常类

public class MyException extends Exception{
    //传递数字大于10
    private int detail;

    public MyException(int a) {
        this.detail = a;
    }

    /**
     * toString 异常的打印信息
     * @return
     */
    @Override
    public String toString() {
        return "MyException{" +
                "detail=" + detail +
                '}';
    }
}

main方法类

public class C14ZiDingYiYiChang {
    /**
     * 可能会抛出异常的方法
     */
    static void test(int a) throws MyException{
        System.out.println("传递的参数是"+a);
        if(a>10){
            throw new MyException(a);
        }
        System.out.println("OK");
    }

    public static void main(String[] args) {
        try {
            test(1);
        } catch (MyException e) {
            e.printStackTrace();
            System.out.println("MyException" + e);
        } finally {
        }
    }

}

  • 异常处理实例
public class C13YiChangChuLi {
    public static void main(String[] args) {
        int a = 2;
        int b = 0;
        new C13YiChangChuLi().test(1,0);

        /**
         * finally 可以不要finally,假设IO,资源,关闭!等,一般放置在 finally 里
         * 假如要不或多个异常,应当从小到大设置catch
         * Ctrl + Alt + t 快速生成捕获异常try-catch
         */
        try {  // try 监控区域
//            System.out.println(a/b);
            if(b==0){
                throw new ArithmeticException(); // 主动抛出异常  一般在方法中使用
            }

           new C13YiChangChuLi().a();
        }catch (ArithmeticException e){  // catch 里的参数,就是想要捕获的类型  捕获异常
            System.out.println("ArithmeticEXception");
        }catch (Error e){
            System.out.println("Error");
            System.exit(0);
            e.printStackTrace();//打印错误的栈信息
        } catch (Exception e){
            System.out.println("Exception");
        }catch (Throwable e){
            System.out.println("Throwable");
        } finally {  // 处理善后工作
            System.out.println("finally");
        }


    }
    public void a(){
        b();
    }
    public void b(){
        a();
    }

    /**
     *  主动抛出异常  一般在方法中使用
     *  假设这方法中,处理不了这个异常。方法上抛出异常  throws
     * @param a
     * @param b
     */
    public void test(int a,int b) throws ArithmeticException{
        if(b==0){
            throw new ArithmeticException();
        }
    }
}

  • 实际应用中的经验总结
    1、处理运行时异常时,采用逻辑去合理规避同时辅助try-catch处理
    2、在多重catch块后面,可以加一个catch (Exception)来处理可能会被遗漏的异常
    3、对于不确定的代码,也可以加上try-catch,处理潜在的异常
    4、尽量去处理异常,切忌只是简单地调用printStackTrace()去打印输出
    5、具体如何处理异常,要根据不同的业务需求和异常类型去决定
    6、尽量添加finally语句块去释放占用的资源
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值