JAVA笔记—异常处理

目录

本笔记包含

异常概述

异常发生的原因

异常事件的分类

Exception分类

异常体系结构图 

JAVA异常处理的方式

异常处理方式一:try-catch-finally

try-catch-finally定义格式

try-catch-finally说明

Try-catch-finally 中的finally的使用

异常处理机制二:throws + 异常类型

 手动抛出异常对象(throw)

用户自定义异常类

常见的异常

运行时异常

编译时异常

 异常常用方法


本笔记包含

异常概述

在Java语言中,将程序在执行过程中发生不正常情况称为:“异常”。

需要提及的是:开发过程中语法错误和逻辑错误不是异常。

所以:

异常是程序中的一些错误,但并不是所有的错误都是异常,并且错误有时候是可以避免的。

异常发生的原因

异常发生的原因有很多,通常包含以下几大类:

  • 用户输入了非法数据。
  • 要打开的文件不存在。
  • 网络通信时连接中断,或者JVM内存溢出。

异常事件的分类

Error():在JAVA虚拟机无法解决的严重问题。如:JVM系统内部错误、资源耗尽等严重情况,一般不编写针对性的代码进行处理。

Exception:其他因编程错误或偶然的外在因素导致的一般性问题,,可以使用针对性代码进行处理。如:空指针,数组角标越界等等。

一般的,我们所说的异常为后者。

Exception分类

Exception又可以分为: ①编译时异常 ②运行时异常

①编译时异常:最具代表的检查性异常是用户错误或问题引起的异常,这是程序员无法预见的。例如要打开一个不存在文件时,一个异常就发生了,这些异常在编译时不能被简单地忽略。

②运行时异常:运行时异常是可能被程序员避免的异常。与检查性异常相反,运行时异常可以在编译时被忽略。

异常体系结构图 

JAVA异常处理的方式

方式一:try-catch-finally

方式二:throws + 异常类型 

1.JAVA提供的是抛抓模型

2.JAVA程序的执行过程中如出现异常,会生成一个异常类对象,该异常对象将提交给Java运行时系统,这个过程被称为抛出异常

3.异常对象的生成:

异常处理方式一:try-catch-finally

try-catch-finally定义格式

try{
   // 代码
}catch(ExceptionName e1){ //可能出现异常的类型名称
   //Catch 块
}catch(ExceptionName e2){
    //Catch 块
}final{
    //final块--可不写
}

try-catch-finally说明

 1.finally是可逆的。

2.使用try将可能出现的异常包起来,在执行的过程中,一旦出现异常,就会生成一个异常类的对象,根据此对象的类型,去catch中进行匹配。

3.一旦try中的异常对象匹配到某个catch时,就进入catch中进行异常的处理,一旦处理完成,就跳出当前的try-catch结构(并没有写final的情况),继续执行期后的代码。

4.catch中的异常类型如果没有子父类关系,则声明的顺序没有要求;

 但是 catch中的异常类型如果有子父类关系,则声明的顺序有要求:子类先,父类后(不遵循则报错)。

5.常用的异常对象处理的方式:①String getmessage() ②prinStackTrace()

6.在try结构中声明的变量,再处了try结构以后,就不能再被调用。

补充:编译时异常,编译通过了但运行不一定能过

Try-catch-finally 中的finally的使用

1..finally是可逆的。

2.finally中声明的是一定会被执行的代码,既使catch中又出现了异常,try中return语句,catch中有trturn语句等情况。

3.像数据库连接,输出流,网络编程Socket等资源,JVM使不能自动回收的,需要我们自己动手进行资源的释放,此时资源的释放,就要声明在finally中。

异常处理机制二:throws + 异常类型

public void test()throws ExceptionName {  //方法体  } 

1."throws + 异常类型"写在方法的声明处。指明此方法执行时,可能会抛出的异常类型。

        一旦当方法体被执行时,出现异常,仍会在代码执行处生成一个异常类对象,此对象满足              throws后面的异常类型时,就会被抛出,异常代码后序的代码不会继续执行

2.体会:try-catch-finally:真正的将异常给了方法的调用者,并没有真正将异常处理掉。

3.开发中如果人选择使用try-catch-finally 还是thrwos?

     3.1 如果父类中被重写的方法没有throws方式处理异常,则子类重写的方法也不能使用                         throws,意味着如果子类重写的方法中有异常,必须使用try-catch-finally处理。

      3.2 执行的方法a中,先后有调用了另外的几个方法,这几个方法是递进关系执行的,                             我们建议这几个方法使用thows的方式执行,而执行的方法a可以考虑使用                                     try-catch-finally方式进行处理。(到调用的最后一层处理)

 手动抛出异常对象(throw)

If(){
}else{
Throw new Exception/RuntimeException(“提示”)
}

用户自定义异常类

  • 所有异常都必须是 Throwable 的子类。
  • 如果希望写一个检查性异常类,则需要继承 Exception 类。
  • 如果你想写一个运行时异常类,那么需要继承 RuntimeException 类。

1.继承现有的异常结构

2.提供全局常量:serialVersionUID

3.提供重载的构造器

public class MyException extends RuntimeException{

    static final long serialVersionUID = -1234567890;
    //重载构造器
    public MyException(){
            
    }
    
}

常见的异常

运行时异常

ArithmeticException当出现异常的运算条件时,抛出此异常。例如,一个整数"除以零"时,抛出此类的一个实例。
ArrayIndexOutOfBoundsException用非法索引访问数组时抛出的异常。如果索引为负或大于等于数组大小,则该索引为非法索引。
ArrayStoreException试图将错误类型的对象存储到一个对象数组时抛出的异常。
ClassCastException当试图将对象强制转换为不是实例的子类时,抛出该异常。
IllegalArgumentException抛出的异常表明向方法传递了一个不合法或不正确的参数。
IllegalMonitorStateException抛出的异常表明某一线程已经试图等待对象的监视器,或者试图通知其他正在等待对象的监视器而本身没有指定监视器的线程。
IllegalStateException在非法或不适当的时间调用方法时产生的信号。换句话说,即 Java 环境或 Java 应用程序没有处于请求操作所要求的适当状态下。
IllegalThreadStateException线程没有处于请求操作所要求的适当状态时抛出的异常。
IndexOutOfBoundsException指示某排序索引(例如对数组、字符串或向量的排序)超出范围时抛出。
NegativeArraySizeException如果应用程序试图创建大小为负的数组,则抛出该异常。
NullPointerException当应用程序试图在需要对象的地方使用 null 时,抛出该异常
NumberFormatException当应用程序试图将字符串转换成一种数值类型,但该字符串不能转换为适当格式时,抛出该异常。
SecurityException由安全管理器抛出的异常,指示存在安全侵犯。
StringIndexOutOfBoundsException此异常由 String 方法抛出,指示索引或者为负,或者超出字符串的大小。
UnsupportedOperationException当不支持请求的操作时,抛出该异常。

编译时异常

ClassNotFoundException应用程序试图加载类时,找不到相应的类,抛出该异常。
CloneNotSupportedException当调用 Object 类中的 clone 方法克隆对象,但该对象的类无法实现 Cloneable 接口时,抛出该异常。
IllegalAccessException拒绝访问一个类的时候,抛出该异常。
InstantiationException当试图使用 Class 类中的 newInstance 方法创建一个类的实例,而指定的类对象因为是一个接口或是一个抽象类而无法实例化时,抛出该异常。
InterruptedException一个线程被另一个线程中断,抛出该异常。
NoSuchFieldException请求的变量不存在
NoSuchMethodException请求的方法不存在

 异常常用方法

1public String getMessage()
返回关于发生的异常的详细信息。这个消息在Throwable 类的构造函数中初始化了。
2public Throwable getCause()
返回一个 Throwable 对象代表异常原因。
3public String toString()
返回此 Throwable 的简短描述。
4public void printStackTrace()
将此 Throwable 及其回溯打印到标准错误流。。
5public StackTraceElement [] getStackTrace()
返回一个包含堆栈层次的数组。下标为0的元素代表栈顶,最后一个元素代表方法调用堆栈的栈底。
6public Throwable fillInStackTrace()
用当前的调用栈层次填充Throwable 对象栈层次,添加到栈层次任何先前信息中。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mao.O

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值