12

本文深入探讨Java异常处理机制,包括异常概念、处理流程、体系结构及自定义异常,强调异常处理的重要性,提供异常处理原则及日志记录方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

异常

一.了解异常概念

生活中:不符合你预期情况的场景就是出现了异常

编程中:程序的运行过程中所发生的不正常的条件,他会中断正在进行的程序

程序运行—>异常—>程序中断运行

二.理解java异常处理机制

**try:**尝试 试图—>执行可能出错的代码

**catch:**捕捉 抓住—>捕获异常

**finally:**最终的 最后的—>无论是否发生异常代码总能运行

**throw:**抛出 扔—>手动抛出异常

**throws:**抛出 扔 (Java编程网络释义:声明异常)—>声明方法可能要抛出的各种异常

**什么事异常处理:**java编程语言使用异常处理机制为程序提供了错误处理的能力

程序中预先设置好对付异常的处理办法:程序运行—>异常—>对异常进行处理—>处理完毕,程序继续运行

异常出现之后JVM在做什么事?

当异常出现之后,JVM会帮你创建对应异常类型的对象(new InputMismatchException(异常提示信息)),如果没有(能处理)的try-catch,采用默认将异常信息行进封装,然后在控制台打印

异常的堆栈跟踪信息:

				我们也可以通过异常对象的方法  print stackTrace() 来输出异常的堆栈跟踪信息

例:

 Exception in thread "main">异常出现在那个线程上

	java.lang Arithmetic Exception: /by zero—>出现了什么类型的异常/异常的缘由信息

	at.cn.kgc.demo2.Demo.main(Demo.java:21)>异常出现的位置(具体到某个包下的某各类的某个方法    类中的第几行)

看异常堆栈信息一般从底往上看,因为往往是上面的错导致下面的错(下面是直接原因,上面是根本原因)

Exception in thread "main" java.util.InputMismatchException
	at java.util.Scanner.throwFor(Scanner.java:864) // 异常出现的根本位置
	at java.util.Scanner.next(Scanner.java:1485)
	at java.util.Scanner.nextInt(Scanner.java:2117)
	at java.util.Scanner.nextInt(Scanner.java:2076)
	at cn.kgc.demo2.Demo2.main(Demo2.java:10) // 异常出现的直接位置

三.会捕捉异常

1.try-catch

try{
    
    //放有可能出现异常的代码
}catch(异常类型  形参名){
    //出现异常解决异常的代码
    
}
//可能有代码段

**正常情况:**与没加效果一致

**出现了异常(声明了可以捕获):**当try块中的某一行代码出现了异常,那么try块中的后续代码将不再执行,直接会跳转到catch块中进行异常的处理,处理完之后继续向下执行。

**出现了异常(异常类型不匹配):**当try块中的某一行代码出现了异常,那么try中的后续代码将不再执行,catch块中声明的异常类型不匹配,那么异常将不会被处理,会采用默认处理方式。(它就好像你没加过try-catch一样)

**联想:**缉毒警察解决不了防暴警察的活。

异常是一种特殊的对象为java.lang.Exception或其子类

2.try-catch-catch

多重catch的情况(联想多重if)

**特点:**当出现异常时,会自上而下的进行判断,判断是否符合catch块中的异常,如果能符合,直接执行此catch块,后续的catch不会触发!

联想多重if记住 最容易匹配的 不要放在前方。  因为多态的原因,如果你将父类放在上方,下方的子类catch就不会执行了!
try-catch-finally

**特点:**无论try块中代码是否有异常,都会执行finally块中的代码片段。

1.出现了退出虚拟机语句 : System.exit(0);

2.return关键字:结束当前方法,返回到方法的调用者处。 当try-catch中同时出现了return和finally块,它会先执行finally块中的代码,然后才执行return。

如果有能够处理的try-catch块,那么JVM会将这个异常对象传给catch(异常类型 形参名)块,然后你就可以通过形参去查看异常相关信息或做对应异常处理了。

注意事项:

try、catch 、finally可以随意组合,但是它们不能单独出现。

四.声明、抛出 异常

不处理 ->

之所以出现throw和throws的目的就是当某个位置出现异常之后,如果它不想处理就可以将此异常上抛,上抛给调用者。

后期的常用形式:为了借助finally块的特点,处理完最终执行内容之后,再将异常上抛。

throws:后面的接的是此方法可能出现的异常的类型 可以同时指定多个 逗号隔开

throw:用来抛出异常对象。

throws 于throw的区别

throwthrows
生成并抛出异常声明方法内抛出了异常
位于方法内部,可作为单独语句使用必须跟在方法参数列表后面,不能单独使用
抛出一个异常对象声明抛出异常类型,后面可以抛出多个异常,用逗号隔开

五.异常体系结构

Throwable

Error Exception

**Error:**程序无法通过代码来修复!必须人工干预解决。 OutOfMemoryError 内存溢出 StackOverflowError 堆栈溢出等 编译错误(语法错误)等

**Exception:**程序执行过程中,可能会出现一些问题,可以提前做好处理工作。

**RuntimException:**运行时异常 不要求程序必须做出处理 例如:InputMismatchException      ArrayIndexOutOfBoundsEception   NullPointerException   ClassCastException     运行期间  可能会出现这些错误!

特点:java虚拟机在编译是不会检查,程序即便可能出现异常在编译时也没错只有运行时会报错

**checked异常:**受检异常/检查异常    例如:FileNotFoundException   ClassNotFoundException  Java程序中人家认为这种异常很可能出现,所以必须要提前解决!增强程序的健壮性!

特点:Java运行时检查,他只要有问题你就得处理否则无法运行

六.自定义异常

当JDK中的异常类型不能满足程序的需要时可以自定义异常类

**特点:**异常种类更加丰富更加具体

使用自定义异常的步骤:

定义异常类——>编写构造方法,继承父类的实现——>实例化自定义异常对象——>抛出异常

七.异常处理原则

  • 异常处理与性能
  • 异常只能用于非正常情况
  • 不要将过于庞大的代码块放在try中
  • 在catch中指定具体的异常类型
  • 需要对捕获的异常做处理

八.日志

在程序运行期间,记录程序的状态,用户操作行为,异常情况的一种东西

.log

日志:

  • 主要用来记录系统中运行中的一些重要操作信息
  • 便于监视系统运行情况,帮助用户提前发现和避开可能出现的问题,或者出现问题后根据日志找到原因

日志是为了以后我们分析程序运行情况和解决问题得根据!

日志记录工具/框架log4j(log for java), logback

什么是log4j??

log4j和logback是俩个受欢迎的日志框架,但两者又有不同

log4j是apache实现的一个开源日志组件

logback同样是由log4j的作者设计完成的,拥有更好的特性,用来取代log4j的一个日志框架

注意: 当你开发程序完成后没有控制台,只能通过日志来看你的程序运行情况

步骤:

  1. 下载jar包(人家编写的代码的字节码压缩包)
  2. 将jar包引入到你的工程内(先建立一个lib文件夹,将jar包放进去,右键jar包进行build path )
  3. 象使用JRE内的类库一样去使用它既可

info(); 记录普通信息的

error(); 记录错误信息的

debug(); 可以用来记录一下特别的普通信息的

九.了解常见异常类型

异常类型说明
Exception异常层次结构的父类
ArithmeticException算术错误情形,如以零做除数
ArrayLndexOutOfBoundsException数组下标越界
NullPointerException尝试访问null对象成员(空指针异常)
ClassNoFoundException不能加载所需的类
IllegalArgumentException方法接收到非法参数
ClassCastException对象强制类型转换出错
NumberFormatException数字格式转换异常,如把“abc”转换成数字
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值