目录
一.异常的概述
二.异常类的层次结构和种类
二.异常的基本用法
2.1异常的捕捉
2.2异常处理代码实现
三.抛出异常
3.1 throw
3.2 throws
四.finally的进一步详解
五.自定义异常类
总结
个人主页:tq02的博客_CSDN博客-C语言,Java领域博主
理想目标:努力学习,向Java进发,拼搏一切,找到一份朝九晚五,有假期的工作,让自己的未来不会有遗憾。
欢迎各位→点赞 + 收藏⭐ + 评论+关注✨本章讲解内容:异常的处理和介绍
使用编译器:IDEA
所谓的异常,就是指程序在运行时可能出现的一些不正常、错误的情况。 例如:除以 0、数组下标越界、类型转换失败、网络地址不能打开、文件不存在等。 异常指的就是程序在 运行时 出现错误时通知 调用者 的一种机制
这就是异常,因为0不能为除数,所以出现了异常。而为什么说JVM显示异常,之后有讲解。
Java为了对异常进行处理,预先已经对各种可能出现的异常定义了很多异常类,每个异常类都代表了一种运行错误或异常。
这张图的最顶层是Throwable类,而它是所有异常或者错误的超类(父类),表中的顺序就是继承 。
而我们着重讲解一下(Exception类的子类):
1.RuntimeException(运行时异常),此异常通常都是:算术异常类、空指针异常类、下标越界异常类、数组元素个数为负异常类等等。都是RuntimeException的子类
而以上的异常类在编译器的表达方式:ArithmeticEception、NullPointerException、IndexOutOfBoundsEception、ArrayIndexOutOfBoundsEcepiond。
2.其它异常类:此异常通常是指:I/O异常、网络地址不能打开、文件未找到等,而这些异常类是指除了RuntimeException类,其他的所有类,而也称为受检类异常的类。
重点:
捕捉?异常如何捕捉?如之前的代码图,这是Java的JVM捕捉出来的异常。但是我们可以自行捕捉异常。
异常处理语法:对可能存在的受检类异常的语句进行监控。
也可以对运行时异常进行监控。
格式如上图,
受检类异常需要使用到其他的类,所以为了更好方便理解,我们现在对运行时异常处理进行代码实例。
使用try{ }catch{ }处理异常的代码
重点来了:如果不使用try{ }catch{ }的语法,那么Java的JVM会自行发现错误并告知。既然JVM会告知,那么为什么还要使用try{ }catch{ }语法呢?
解释:如果程序发生了异常,系统会根据异常而终止程序运行,但如果用户想让程序继续执行,便可以通过使用try{ }catch{ }的语法处理异常。
抛出异常,是指告知编译器不要在乎该异常。Java程序定义好的程序异常或者错误时,由系统自动抛出,但是如果程序员想主动抛出异常,则可以使用throw。
代码实现:
public static void main(String[] args) {
System.out.println(divide(10, 0));
}
public static int divide(int x, int y) {
if (y == 0) {
throw new ArithmeticException("抛出除 0 异常");
}
return x / y;
}
// 执行结果
Exception in thread "main" java.lang.ArithmeticException: 抛出除 0 异常
at demo02.Test.divide(Test.java:14)
at demo02.Test.main(Test.java:9)
在这个代码中,我们可以根据实际情况来抛出需要的异常. 在构造异常对象同时可以指定一些描述性信息。
如果一个方法的头部申明该方法可能抛出异常了,则使用throws来完成。
语法格式:public void fun() throws 异常类{ ....... }
使用 throws 声明抛出异常的一般情况是:当前方法不知道如何(或者不想)处理方法中可能发生的异常,于是不使用 try-catch 监控和捕捉异常,而是在方法声明中说明该方法将有可能抛出异常,由方法的上一级调用者处理,自己不再处理。可以理解为踢皮球,没有人想解决这个问题,直到有人愿意解决为止。
代码实例
public class Tex3 {
public static void fun()throws IOException
{
FileInputStream input = new FileInputStream("Ajava");
}
public static void main(String[] args){
try
{
fun();
}catch(IOException e)
{
System.out.println("咳咳");
}
}
}
从代码中,我们可以看出来。fun()函数使用了throws声明了抛出异常,从而不解决文件是否可以找到的,受检类异常。而当函数结束之后,异常就丢回给了调用者main() 函数,因此我们可以看见main函数中使用了try-catch 异常处理
finally是异常处理语法格式的最后一步,不管监控区是否出现了异常,都会执行,但是否想过一种特殊的情况,调用函数返回时呢?
例如代码:
public class Tex3 {
public static int fun()
{
int x=20;
try
{
if(x>10)
return 10;
}catch(Exception e)
{
}
finally{
return 20;
}
}
public static void main(String[] args){
System.out.println(fun());;
}
}
该代码返回的值为20,并非10,说明了一点,无论什么情况,一点会执行finally,哪怕返回值时,也需要执行finally;
用户定义的异常类都得继承Exception类,所以需要自定义时异常时,需要继承RuntimeException,且定义异常类时,需要提供2种构造函数:一种是无参数的构造函数,一种是带有一个字符串的构造函数。
1、自定义异常类继承Exception类代码:
public class MyException extends Exception {
//异常信息
private String message;
//构造函数
public MyException(String message){
super(message);
this.message = message;
}
2.在要抛出异常的函数使用throws关键字
public class UseMyException {
private String name;
private String password;
public UseMyException(String name,String password){
this.name = name;
this.password = password;
}
public void throwException(String password) throws MyException{
if (!this.password.equals(password)){
throw new MyException("密码不正确!");
}
}
}
3.测试,使用try-catch处理异常
public class TestException {
@org.junit.Test
public void test(){
UseMyException ex = new UseMyException("admin","123");
try{
ex.throwException("1234");
}catch (MyException me){
System.out.println("MyException:"+me.getMessage());
}
}
}
以上便是自定义异常类的方法和步骤。
异常处理主要用于之后的文件、打开网络地址、输入输出I/O等。 其次重要的是自定义异常类。慢慢看,一定一定要有耐心啊。
最后再介绍一个printStackTrace()方法,用处,在异常处理中用于catch块,可以输出代码哪行有问题。使用方法:异常类名的形参名.printStackTrace()。