关于java的异常处理

本文详细介绍了Java中的异常处理机制,包括异常类型等级、try-catch-finally结构的应用、异常的主动抛出与处理,以及如何使用throw和throws关键字。通过实例演示了如何捕获和处理不同类型的异常,强调了异常处理在编程中的重要性。
摘要由CSDN通过智能技术生成

关于java的异常处理

我们在上一篇文章中,对java中的异常有了一个初步的了解,本篇文章我们来了解一下异常的处理机制,如何抛出异常,如何捕捉异常😀

关于java的异常

一、异常类型等级

在这里插入图片描述

二、关键字

  • try
  • catch
  • finally
  • throw
  • throws

1、我们新建一个测试类,在里面声明两个变量a和b,a=1,b=0,输出a/b(我们知道这是错误的,所以要做异常处理)。

package exception;

public class Demo01 {

    public static void main(String[] args) {
        int a=1;
        int b=0;

        System.out.println(a/b);
    }
}

我们输出一下,发现这是ArithmeticException类型的异常(算术异常)

Exception in thread "main" java.lang.ArithmeticException: / by zero
	at exception.Demo01.main(Demo01.java:8)

2、我们用try catch做一下异常处理🐶,(fianlly可以不用,但是我们后期学习IO流的时候,要把资源关闭,可以理解为scanne.close)

package exception;

public class Demo01 {

    public static void main(String[] args) {
        int a=1;
        int b=0;
        try //监控区域
        {
            System.out.println(a/b);
        }catch (ArithmeticException e)//捕获异常
        {
            System.out.println("程序出现异常,变量b不能为0");
        }finally//处理善后工作
        {
            System.out.println("finally");
        }
    }
}

三、try catch 结构

try//异常监控
{
	//需要监控的代码
}
catch()//异常类型捕获
{
	//捕捉后执行的代码
}

1、我们做了异常处理以后,再执行一下代码,就会看到输出的是我们捕捉后进行处理的代码了。

程序出现异常,变量b不能为0
finally

2、我们再来定义两个方法,让他们互相调用。

package exception;

import struct.Test;

public class Demo01 {

    public static void main(String[] args) {
        int a=1;
        int b=0;
        try //监控区域
        {
            new Demo01().a();
        }catch (ArithmeticException e)//捕获异常
        {
            System.out.println("不能互相调用!");
        }finally//处理善后工作
        {
            System.out.println("finally");
        }
    }
    public void a(){b();}
    public void b(){a();}
}

3、我们执行以下代码,发现输出了finally,但是并没有捕捉到异常。

finally
Exception in thread "main" java.lang.StackOverflowError
	at exception.Demo01.b(Demo01.java:22)
	at exception.Demo01.a(Demo01.java:21)
	at exception.Demo01.b(Demo01.java:22)
	at exception.Demo01.a(Demo01.java:21)
  • finally被正常输出出来了,因为它是善后工作所以执行。
  • 没有捕捉到是因为,这个异常是个Error,是错误(StackOverflowError),所以要换一种方式捕捉,可以用Throwable,因为它的类型是最高的,catch(异常类型)
package exception;

import struct.Test;

public class Demo01 {

    public static void main(String[] args) {
        int a=1;
        int b=0;
        try //监控区域
        {
            new Demo01().a();
        }catch (Throwable e)//捕获异常
        {
            System.out.println("不能互相调用!");
        }finally//处理善后工作
        {
            System.out.println("finally");
        }
    }
    public void a(){b();}
    public void b(){a();}
}

4、catch可以是多个,有点类似else if 满足其中一个就可以,所以要把最大的写在最后,如果写在前面的话,后面的异常处理就不执行了🤔

  • 假设要捕获多个异常,从小到大捕获。
try//异常监控
{
	//需要监控的代码
}
catch(Error e)//异常类型捕获
{
	//捕捉后执行的代码
}
catch(Exception e)//Exception相对大一点
{

}
.....
catch(Throwable e)//最大的写在最后
{
    
}

四、快捷键

  • CTRL+ALT+T
package exception;

public class Demo01 {

    public static void main(String[] args) {
        int a=1;
        int b=0;

        System.out.println(a/b);//选中,CTRL+ALT+T
    }
}

在这里插入图片描述

  • 有很多结构都是可以进行选择的,我们这里选择try/catch,然后就会自动生成一段代码出来了🐱
package exception;

public class Demo02 {
    public static void main(String[] args) {
        int a=1;
        int b=0;
        try {
            System.out.println(a/b);
        } catch (Exception e) {
            throw new RuntimeException(e);//打印错误信息
        }
    }
}
package exception;

public class Demo02 {
    public static void main(String[] args) {
        int a=1;
        int b=0;
        try
        {
            System.out.println(a/b);
        }
        catch (Exception e)
        {
            System.exit(1);//结束程序
            throw new RuntimeException(e);
        }
    }
}

五、主动抛出异常

  • throw
  • throws
  • 二者的区别还是非常大的。

有时候我们知道代码中逻辑会有问题,所以我们选择去主动抛出异常,我们先来看一下throw。

package exception;

public class Demo02 {
    public static void main(String[] args) {
        int a=1;
        int b=0;
        try
        {
            if (b==0)
            {
                throw new ArithmeticException();//主动抛出异常
            }
            System.out.println(a/b);
        }
        catch (Exception e)
        {
            //System.exit(1);
            throw new RuntimeException(e);
        }
    }
}
  • 上面代码执行的时候不会抛出什么,也看不见什么。
  • 抛出异常大多数用在方法里面,所以我们在方法中试一下。

我们写一个除数的方法。

public void test(int a,int b)
{            
	if (b==0)
    {
       throw new ArithmeticException();//主动抛出异常
    }
	System.out.println(a/b);
}

我们在上面调用以下这个方法,运行以下,就会抛出异常。

package exception;

public class Demo02 {
    public static void main(String[] args) {
        new Demo02().test(1,0);
    }
}
Exception in thread "main" java.lang.RuntimeException: java.lang.ArithmeticException
	at exception.Demo02.main(Demo02.java:18)
  • 如果在方法中,处理不了这个异常,我们可以在方法上抛出异常,这个时候就用到了throws
public void test(int a,int b) throws ArithmeticException 
{            
	if (b==0)
    {
       throw new ArithmeticException();//主动抛出异常
    }
	System.out.println(a/b);
}

这里我们调用的时候,用try catch 捕获一下。

package exception;

public class Demo02 {
    public static void main(String[] args) {
                try {
            new Demo03().test(1,0);
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
}

捕捉的好处,就是如果不捕获异常的话,程序碰到异常就直接终止了,但是捕获了以后,还是可以继续运行的,所以异常捕获十分的重要!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值