当前位置: 首页 > news >正文

12. Java异常及异常处理处理

Java —— 异常及处理

        • 1. 异常
        • 2. 异常体系
        • 3. 常见Exception
        • 4. 异常处理
          • 4.1 try finally catch关键字
          • 4.2 throws和throw 自定义异常
          • 4.3 finally,final,finalize三者的区别

1. 异常
异常:在程序执行过程中发生的意外状况,可能导致程序中断或产生错误结果
异常对象:java(面向对象)将错误用类来描述,一旦程序执行错误,将会创建对应的错误对象(用以向程序员或用户展示错误原因等)
异常处理的意义:提高代码的健壮性和可靠性,使程序可以处理非预期的情景,并且继续正常的处理
2. 异常体系
异常超类:Thorwable类(表示可抛出)是所有异常和错误的超类
异常的两个子类:Exception异常类,Error错误异常类
Exception程序捕捉处理的异常:表示由于网络故障、文件损坏、设备错误、用户输入非法等情况导致的异常
Error系统错误:表示Java运行时环境出现的错误(JVM内存资源耗尽)
  • java异常体系图
    在这里插入图片描述

Throwable的父类也是Object,继承其父类的 getClass()和getName()方法

  • 常用方法
// 返回抛出异常的详细信息
public string getMessage();
public string getLocalizedMessage();
//返回异常发生时的简要描述
public public String toString()
//打印异常信息到标准输出流上
public void printStackTrace();
public void printStackTrace(PrintStream s);
public void printStackTrace(PrintWriter s)
//记录栈帧的的当前状态
public synchronized Throwable fillInStackTrace();
package exception;/*** 常见使用方法*/
public class ExceptionAPI {public static void main(String[] args) {System.out.println("程序开始!");try {String line = "1i0";System.out.println(Integer.parseInt(line));} catch (NumberFormatException e) {// 显示红色报错信息e.printStackTrace();// 获取错误信息System.out.println("错误信息:" + e.getMessage());System.out.println("错误信息Localized:" + e.getLocalizedMessage());System.out.println("简要描述:" + e.toString());System.out.println("当前状态:" + e.fillInStackTrace());}System.out.println("结束");}
}
3. 常见Exception
Exception的两类异常:RuntimeException运行时异常(非受控),CheckedException编译时异常(受控)

常见UncheckedException异常

异常异常描述
ArrayIndexOutOfBoundsException数组越界异常
NulPointerException空指针异常
llegalArgumentException非法参数异常
NegativeArraySizeException数组长度为负异常
llegalStateException非法状态异常
ClassCastException类型转换异常

常见RuntimeException异常

异常异常描述
NoSuchFieldException表示该类没有指定名称抛出来的异常
NoSuchMethodException表示该类没有指定方法抛出来的异常
llegalAccessException不允许访问某个类的异常
ClassNotFoundException类没有找到抛出异常
4. 异常处理
4.1 try finally catch关键字

组合:try...catch 对某一段代码可能抛出异常进行的捕获
   try...finally 对一段代码不管执行情况如何,都会走finally中的代码
   try...catch...finally 对异常捕获后,再走fimally中的代码逻辑

  • 异常处理过程:一般是子类型在前,超类型在后

对指定代码内容添加一定包围功能(try…finally)快捷键:ctrl+alt+t

try…catch

package exception;
/*** java异常处理机制* java异常超类:Throwable* 两个子类:Error,表示系统级别错误*/
public class TryCatch {public static void main(String[] args) {System.out.println("程序开始执行!");// try catch异常处理try{String line = "";
//             String line = null;System.out.println(line.length());System.out.println(line.charAt(0));} catch (NullPointerException e){// 程序没有异常就不会执行该异常处理System.out.println("异常:空指针异常!");} catch (StringIndexOutOfBoundsException e){// try中的代码执行捕获到第一个异常之后,直接跳到相应的处理机制,后面的异常将不再执行System.out.println("异常:索引超出范围!");} catch (NoSuchFieldError | StackOverflowError e){// 多个异常的相同处理机制System.out.println("发生异常!");} catch (Exception e){// 超类异常(多种异常,超类异常一般写在最后)System.out.println("出错!");}System.out.println("执行完毕!");}
}

try…catch…finally

package exception;import java.io.FileOutputStream;
import java.io.IOException;/*** finally 关键字用来创建在 try 代码块后面执行的代码块* 无论是否发生异常,finally 代码块中的代码总会被执行* 在 finally 代码块中,可以运行清理类型等收尾善后性质的语句** @author LongYongchuan*/
public class FinallyDemo {public static void main(String[] args) {System.out.println("程序开始!");try{String line = "11";System.out.println(line.length());} catch (Exception e) {System.out.println("出错了!");} finally {System.out.println("finally");}System.out.println("程序结束!");FileOutputStream fos = null;try {fos = new FileOutputStream("./document/fos.txt");fos.write(5);} catch (IOException e) {throw new RuntimeException(e);} finally {try {fos.close();} catch (IOException e) {throw new RuntimeException(e);}}}
}

编译器的自动关闭特性(只是编译器认可)

  • 只有实现了AutoCloseable接口的类才能在try后面加(进行初始化),java中所有流都实现了该接口
package exception;import java.io.FileOutputStream;
import java.io.IOException;public class AutoClose {public static void main(String[] args) {// 编译器优化代码(只有实现了AutoCloseable接口的类)try (// 初始化FileOutputStream fos = new FileOutputStream("./document/fos.dat")) {fos.write(1);} catch (IOException e) {e.printStackTrace();}}
}
4.2 throws和throw 自定义异常

Java中,异常就是一个对象,它能够被程序员自定义抛出或者应用程序抛出,必须借助于throws和throw 语句来定义抛出异常
throws和throw通常是成对出现的:
      throws 语句用在方法声明后面,表示再抛出异常,由该方法的调用者来处理,抛出一个异常实例
      throw语句用在方法体内,表示抛出异常,由方法体内的语句处理

  • 自定义异常
  • Java异常机制可以保证程序更安全和更健壮,虽然Java类库已经提供很多可以直接处理异常的类,但是有时候为了更加精准地捕获和处理异常以呈现更好的用户体验,需要开发者自定义异常
  • 自定义异常
    1.类名要做到见名知义
    2.必须继承自Exception(直接或间接继承)
    3.提供从超类异常定义的所有构造器
    1. throw和throws通常成对出现(单独的throw对Exception时编译不通过,需要使用throws在方法上对异常抛出处理)
    2. 一般RuntimeException和throw使用,其他异常需结合throw和throws使用,一般不要在main方法上抛出异常(不负责的体现)
    3. 方法中出现throw异常时,throw后面的代码将不执行,而直接进入异常处理机制
  • 自定义异常
package exception;public class IllegalAgeException extends Exception{// alt+insert键生成public IllegalAgeException() {}public IllegalAgeException(String message) {super(message);}public IllegalAgeException(String message, Throwable cause) {super(message, cause);}public IllegalAgeException(Throwable cause) {super(cause);}public IllegalAgeException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) {super(message, cause, enableSuppression, writableStackTrace);}
}
  • 抛出异常
package exception;public class Person{private String name;private int age;private char gender;private String[] otherInfo;public Person() {}public Person(String name, int age, char gender, String[] otherInfo) {this.name = name;this.age = age;this.gender = gender;this.otherInfo = otherInfo;}public String getName() {return name;}// 异常处理throws关键字(使用在方法声明之后,抛出异常处理,该异常由方法调用者处理)public void setName(String name){if (name.length() <= 0 || name.length() >= 5){// throw和throws通常成对出现(单独的throw对Exception时编译不通过,需要使用throws在方法上对异常抛出处理)throw new RuntimeException("名字长度不符合汉文名字");}this.name = name;}public int getAge() {return age;}public void setAge(int age) throws IllegalAgeException{// 抛出异常throw关键字if (age < 0 || age >100){// 一般RuntimeException和throw使用,其他异常需结合throw和throws使用throw new IllegalAgeException("年龄不合法");// 出现异常时,throw相当于return直接结束,不执行this.age = age;}this.age = age;System.out.println("年龄:" + age);}public char getGender() {return gender;}public void setGender(char gender) {this.gender = gender;}public String[] getOtherInfo() {return otherInfo;}public void setOtherInfo(String[] otherInfo) {this.otherInfo = otherInfo;}}
  • 异常处理
package exception;/*** throw关键字*/
public class ThrowDemo {// 一般不要在main方法上抛出异常public static void main(String[] args){Person person = new Person();// throw单独的异常一般不必须抛出person.setName("萨克");// 使用throw和throws抛出的异常必须处理try {// 方法调用者处理异常person.setAge(50);} catch (IllegalAgeException e) {throw new RuntimeException(e);}System.out.println("此人姓名:" + person.getName());}
}

注:
  允许子类方法抛出父类方法的部分异常
  允许子类方法不再抛出异常
  允许子类方法抛出父类方法声明的子类型异常


  不允许子类方法抛出额外异常
  不允许子类方法抛出父类方法声明异常的超类型异常

4.3 finally,final,finalize三者的区别
  • finally 关键字用于定义在 try-catch 语句块中始终执行的代码块
  • final 关键字用于修饰类、方法和变量,分别表示最终类、最终方法和常量
  • finalize() 方法是 Object 类中的方法,用于对象在被垃圾回收前进行资源清理的操作
  1. finallyfinally 是 Java 中的一个关键字,用于定义在 try-catch 语句块中的一个代码块。无论是否发生异常,finally 代码块始终会被执行(常用于进行清理工作,例如关闭文件、释放资源等)
try {// 可能引发异常的代码
} catch (Exception e) {// 异常处理逻辑
} finally {// 始终会执行的代码,用于清理工作
}
  1. finalfinal 是用来修饰类、方法和变量的关键字
  • 当用 final 修饰一个类时,表示该类不能被继承,即该类为最终类
  • 当用 final 修饰一个方法时,表示该方法不能被子类重写,即该方法为最终方法
  • 当用 final 修饰一个变量时,表示该变量的值不能被修改,即该变量为常量
final class FinalClass {// 最终类,不能被继承
}class SuperClass {final void finalMethod() {// 最终方法,不能被重写}
}public class Example extends SuperClass {// 尝试重写finalMethod()会导致编译错误
}class MyClass {final int MAX_VALUE = 10; // 常量,不能被修改
}
  1. finalize()finalize() 是 Object 类中的一个方法,用于在对象被垃圾回收前进行资源清理的操作。当垃圾回收器准备回收一个对象时,会先调用其 finalize() 方法(如果该对象重写了该方法),然后才对其进行垃圾回收。通常用于释放非Java堆内存资源,如关闭文件、释放连接等。但是,它已经过时,不推荐使用。
class MyClass {@Overrideprotected void finalize() throws Throwable {// 对象的资源清理操作}
}

相关文章:

12. Java异常及异常处理处理

Java —— 异常及处理 1. 异常2. 异常体系3. 常见Exception4. 异常处理4.1 try finally catch关键字4.2 throws和throw 自定义异常4.3 finally&#xff0c;final&#xff0c;finalize三者的区别 1. 异常 异常&#xff1a;在程序执行过程中发生的意外状况&#xff0c;可能导致程…...

自定义hooks函数

体会1 1、js文件中定义useXX函数 export function usetestY() {const count ref(10);const doubleCount computed(() > count.value * 2);return {count,doubleCount,}; } 2、在vue文件中使用useXX函数 import { usetestY } from ./data;const { count, doubleCount } …...

Linux系统及Docker安装RabbitMq

目录 一、linux系统安装 1、上传文件 2、在线安装依赖环境 3、安装Erlang 4、安装RabbitMQ 5、开启管理界面及配置 6、启动 7、删除mq 二、docker安装 1、上传mq.tar包或使用命令拉取镜像 2、启动并运行 3、访问mq 一、linux系统安装 1、上传文件 2、在线安装依赖环…...

山东省赛二阶段第一部分解题思路

提交攻击者的IP地址 192.168.1.7 这个直接awk过滤一下ip次数&#xff0c;这个ip多得离谱&#xff0c;在日志里面也发现了它的恶意行为&#xff0c;后门&#xff0c;反弹shell 识别攻击者使用的操作系统 Linux 找出攻击者资产收集所使用的平台 shodan 提交攻击者目…...

WebGoat 靶场 JWT tokens 四 五 七关通关教程

文章目录 webGoat靶场第 四 关 修改投票数第五关第七关 你购买书&#xff0c;让Tom用户付钱 webGoat靶场 越权漏洞 将webgoat-server-8.1.0.jar复制到kali虚拟机中 sudo java -jar webgoat-server-8.1.0.jar --server.port8888解释&#xff1a; java&#xff1a;这是用于执行…...

【单元测试】如何使用 JUnit5 框架?

JUnit5 单元测试框架使用教程 一、Junit5 是什么&#xff1f; Junit5是一个用于在Java平台上进行单元测试的框架。JUnit 5 框架主要由三部分组成&#xff1a;JUnit Platform、JUnit Jupiter 和 JUnit Vintage。 JUnit Platform&#xff1a;定义了测试引擎的 API&#xff0c;是…...

C#封装、继承和多态的用法详解

大家好&#xff0c;今天我们将来详细探讨一下C#中封装、继承和多态的用法。作为C#的三大面向对象的特性&#xff0c;这些概念对于程序员来说非常重要&#xff0c;因此我们将对每个特性进行详细的说明&#xff0c;并提供相应的示例代码。 目录 1. 封装&#xff08;Encapsulati…...

数据结构与算法(持续更新)

线性表 单链表 单链表的定义 由于顺序表的插入删除操作需要移动大量的元素&#xff0c;影响了运行效率&#xff0c;因此引入了线性表的链式存储——单链表。单链表通过一组任意的存储单元来存储线性表中的数据元素&#xff0c;不需要使用地址连续的存储单元&#xff0c;因此它…...

HDLbits: ece241 2014 q4

module top_module (input clk,input x,output z ); reg [2:0] Q;always(posedge clk)beginQ[0] < Q[0] ^ x;Q[1] < (~Q[1]) & x;Q[2] < (~Q[2]) | x;z < ~(| Q[2:0]); //错误&#xff01;&#xff01;&#xff01;&#xff01;endendmodule 正确答案&#xf…...

LuatOS-SOC接口文档(air780E)-- gmssl - 国密算法

sm.sm2encrypt(pkx,pky,data)# sm2算法加密 参数 传入值类型 解释 string 公钥x,必选 string 公钥y,必选 string 待计算的数据,必选,最长255字节 返回值 返回值类型 解释 string 加密后的字符串, 原样输出,未经HEX转换 例子 local originStr "encryptio…...

【线性代数及其应用 —— 第一章 线性代数中的线性方程组】-1.线性方程组

所有笔记请看&#xff1a; 博客学习目录_Howe_xixi的博客-CSDN博客https://blog.csdn.net/weixin_44362628/article/details/126020573?spm1001.2014.3001.5502思维导图如下&#xff1a; 内容笔记如下&#xff1a;...

vue实现拖拽排序

在业务中列表拖拽排序是比较常见的需求&#xff0c;常见的JS拖拽库有Sortable.js&#xff0c;Vue.Draggable等&#xff0c;大多数同学遇到这种需求也是更多的求助于这些JS库&#xff0c;其实&#xff0c;使用HTML原生的拖放事件来实现拖拽排序并不复杂&#xff0c;结合Vue的tra…...

IS-IS

二、IS-IS中的DIS与OSPF中的DR Level-1和Level-2的DIS是分别选举的&#xff0c;用户可以为不同级别的DIS选举设置不同的优先级。DIS的选举规则如下&#xff1a;DIS优先级数值最大的被选为DIS。如果优先级数值最大的路由器有多台&#xff0c;则其中MAC地址最大的路由器会成为DI…...

【MySQL】为什么使用B+树做索引

MySQL的innoDB引擎使用的是B树的结构来存储索引的&#xff0c;那么为什么会使用B树呢&#xff1f;为什么不使用其他的结构?本篇我们深入MySQL底层来了解B树。本文中说到的MySQL都是InnoDB引擎的 在这之前&#xff0c;先了解一下InnoDB是如何存储数据的 MySQL是根据数据页的方式…...

php 安装mongodb扩展模块,rdkafka模块

mongodb mongodb扩展下载 选择php版本&#xff0c;根据报错提示&#xff0c;选择扩展对应的版本选择非安全进程将php_mongodb.dll放到php/ext目录下修改php.ini配置&#xff0c;添加extensionphp_mongodb.dll开启php_mongodb扩展&#xff0c;重启服务php -m 查看是否开启成功…...

【数据结构】初探时间与空间复杂度:算法评估与优化的基础

&#x1f6a9;纸上得来终觉浅&#xff0c; 绝知此事要躬行。 &#x1f31f;主页&#xff1a;June-Frost &#x1f680;专栏&#xff1a;数据结构 &#x1f525;该文章主要了解算法的时间复杂度与空间复杂度等相关知识。 目录&#xff1a; &#x1f30f; 时间复杂度&#x1f52d…...

SpringCloud Alibaba - Sentinel 限流规则(案例 + JMeter 测试分析)

目录 一、Sentinel 限流规则 1.1、簇点链路 1.2、流控模式 1.2.1、直接流控模式 1.2.2、关联流控模式 a&#xff09;在 OrderController 中新建两个端点. b&#xff09;在 Sentinel 控制台中对订单查询端点进行流控 c&#xff09;使用 JMeter 进行测试 d&#xff09;分…...

uniapp 条件编译 APP 、 H5 、 小程序

一、#ifdef、#ifndef、 #endif三者的区别、 标识作用#ifdef仅在某个平台上使用#ifndef在除了这个平台的其他平台上使用(非此平台使用&#xff09;#endif结束条件编译 二、平台标识 标识平台APP-PLUS5AppMP微信小程序/支付宝小程序/百度小程序/头条小程序/QQ小程序MP-WEIXIN微…...

深度学习——权重衰减(weight_decay)

深度学习——权重衰减&#xff08;weight_decay) 文章目录 前言一、权重衰减1.1. 范数与权重衰减1.2. 高维线性回归1.3. 从零开始实现1.3.1.初始化模型参数1.3.2. 定义L₂范数惩罚1.3.3. 定义训练代码实现1.3.4. 不管正则化直接训练1.3.5. 使用权重衰减 1.4. 简洁实现 总结 前言…...

nignx如何部署让前端不用清缓存就可以部署

在Nginx中&#xff0c;可以使用以下方法来部署前端应用程序&#xff0c;使前端用户无需清空缓存即可进行部署&#xff1a; 1、使用版本号&#xff1a;在前端应用程序的构建过程中&#xff0c;可以添加一个独特的版本号到应用程序的名称中。每次部署时&#xff0c;将版本号更新…...

AI-调查研究-01-正念冥想有用吗?对健康的影响及科学指南

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; &#x1f680; AI篇持续更新中&#xff01;&#xff08;长期更新&#xff09; 目前2025年06月05日更新到&#xff1a; AI炼丹日志-28 - Aud…...

7.4.分块查找

一.分块查找的算法思想&#xff1a; 1.实例&#xff1a; 以上述图片的顺序表为例&#xff0c; 该顺序表的数据元素从整体来看是乱序的&#xff0c;但如果把这些数据元素分成一块一块的小区间&#xff0c; 第一个区间[0,1]索引上的数据元素都是小于等于10的&#xff0c; 第二…...

MFC内存泄露

1、泄露代码示例 void X::SetApplicationBtn() {CMFCRibbonApplicationButton* pBtn GetApplicationButton();// 获取 Ribbon Bar 指针// 创建自定义按钮CCustomRibbonAppButton* pCustomButton new CCustomRibbonAppButton();pCustomButton->SetImage(IDB_BITMAP_Jdp26)…...

Golang dig框架与GraphQL的完美结合

将 Go 的 Dig 依赖注入框架与 GraphQL 结合使用&#xff0c;可以显著提升应用程序的可维护性、可测试性以及灵活性。 Dig 是一个强大的依赖注入容器&#xff0c;能够帮助开发者更好地管理复杂的依赖关系&#xff0c;而 GraphQL 则是一种用于 API 的查询语言&#xff0c;能够提…...

微信小程序 - 手机震动

一、界面 <button type"primary" bindtap"shortVibrate">短震动</button> <button type"primary" bindtap"longVibrate">长震动</button> 二、js逻辑代码 注&#xff1a;文档 https://developers.weixin.qq…...

Neo4j 集群管理:原理、技术与最佳实践深度解析

Neo4j 的集群技术是其企业级高可用性、可扩展性和容错能力的核心。通过深入分析官方文档,本文将系统阐述其集群管理的核心原理、关键技术、实用技巧和行业最佳实践。 Neo4j 的 Causal Clustering 架构提供了一个强大而灵活的基石,用于构建高可用、可扩展且一致的图数据库服务…...

【JavaSE】绘图与事件入门学习笔记

-Java绘图坐标体系 坐标体系-介绍 坐标原点位于左上角&#xff0c;以像素为单位。 在Java坐标系中,第一个是x坐标,表示当前位置为水平方向&#xff0c;距离坐标原点x个像素;第二个是y坐标&#xff0c;表示当前位置为垂直方向&#xff0c;距离坐标原点y个像素。 坐标体系-像素 …...

Maven 概述、安装、配置、仓库、私服详解

目录 1、Maven 概述 1.1 Maven 的定义 1.2 Maven 解决的问题 1.3 Maven 的核心特性与优势 2、Maven 安装 2.1 下载 Maven 2.2 安装配置 Maven 2.3 测试安装 2.4 修改 Maven 本地仓库的默认路径 3、Maven 配置 3.1 配置本地仓库 3.2 配置 JDK 3.3 IDEA 配置本地 Ma…...

重启Eureka集群中的节点,对已经注册的服务有什么影响

先看答案&#xff0c;如果正确地操作&#xff0c;重启Eureka集群中的节点&#xff0c;对已经注册的服务影响非常小&#xff0c;甚至可以做到无感知。 但如果操作不当&#xff0c;可能会引发短暂的服务发现问题。 下面我们从Eureka的核心工作原理来详细分析这个问题。 Eureka的…...

永磁同步电机无速度算法--基于卡尔曼滤波器的滑模观测器

一、原理介绍 传统滑模观测器采用如下结构&#xff1a; 传统SMO中LPF会带来相位延迟和幅值衰减&#xff0c;并且需要额外的相位补偿。 采用扩展卡尔曼滤波器代替常用低通滤波器(LPF)&#xff0c;可以去除高次谐波&#xff0c;并且不用相位补偿就可以获得一个误差较小的转子位…...