java基础异常Exception代码讲解总结
- 格式:docx
- 大小:597.37 KB
- 文档页数:14
Java异常(Exception)处理以及常见异常总结⽬录前⾔异常简介异常类型总结前⾔很多事件并⾮总是按照⼈们⾃⼰设计意愿顺利发展的,经常出现这样那样的异常情况。
例如:你计划周末郊游,计划从家⾥出发→到达⽬的→游泳→烧烤→回家。
但天有不测风云,当你准备烧烤时候突然天降⼤⾬,只能终⽌郊游提前回家。
“天降⼤⾬”是⼀种异常情况,你的计划应该考虑到这样的情况,并且应该有处理这种异常的预案。
计算机程序的编写也需要考虑处理这些异常情况。
异常(exception)是在运⾏程序时产⽣的⼀种异常情况,已经成为了衡量⼀门语⾔是否成熟的标准之⼀。
⽬前的主流编程语⾔java也提供了异常处理机制。
异常简介Java中的异常⼜称为例外,是⼀个在程序执⾏期间发⽣的事件,它中断正在执⾏程序的正常指令流。
为了能够及时有效地处理程序中的运⾏错误,必须使⽤异常类,这可以让程序具有极好的容错性且更加健壮。
在 Java 中⼀个异常的产⽣,主要有如下三种原因:1. Java 内部错误发⽣异常,Java 虚拟机产⽣的异常。
2. 编写的程序代码中的错误所产⽣的异常,例如空指针异常、数组越界异常等。
3. 通过 throw 语句⼿动⽣成的异常,⼀般⽤来告知该⽅法的调⽤者⼀些必要信息。
Java 通过⾯向对象的⽅法来处理异常。
在⼀个⽅法的运⾏过程中,如果发⽣了异常,则这个⽅法会产⽣代表该异常的⼀个对象,并把它交给运⾏时的系统,运⾏时系统寻找相应的代码来处理这⼀异常。
我们把⽣成异常对象,并把它提交给运⾏时系统的过程称为拋出(throw)异常。
运⾏时系统在⽅法的调⽤栈中查找,直到找到能够处理该类型异常的对象,这⼀个过程称为捕获(catch)异常。
例 1为了更好地理解什么是异常,下⾯来看⼀段⾮常简单的 Java 程序。
下⾯的⽰例代码实现了允许⽤户输⼊ 1~3 以内的整数,其他情况提⽰输⼊错误。
package io.renren.config;import java.util.Scanner;/*** Created by LiYangYong*/public class TestException {public static void main(String[] args) {System.out.println("请输⼊您的选择:(1~3 之间的整数)");Scanner input = new Scanner(System.in);int num = input.nextInt();switch (num) {case 1:System.out.println("one");break;case 2:System.out.println("two");break;case 3:System.out.println("three");break;default:System.out.println("error");break;}}}正常情况下,⽤户会按照系统的提⽰输⼊ 1~3 之间的数字。
java三种异常处理方法Java是一种流行的编程语言,但是在编写程序时常常会遇到各种异常。
为了使程序更加健壮和稳定,我们需要使用异常处理机制。
Java中有三种异常处理方法:1. try-catch语句try-catch语句是最常用的异常处理方法。
它的基本语法如下: ```try {// 可能会抛出异常的代码} catch (Exception e) {// 异常处理代码}```在try块中,我们编写可能会抛出异常的代码。
如果这些代码抛出了异常,那么程序就会跳转到catch块中。
catch块中的代码会处理异常,可以输出异常信息,也可以进行其他操作。
2. throws关键字throws关键字可以将异常抛给调用该方法的上一级方法处理。
它的语法如下:```public void method() throws Exception {// 可能会抛出异常的代码}```在方法声明中使用throws关键字,表明该方法可能会抛出某种异常。
如果抛出了异常,异常将会被抛给该方法的调用者处理。
3. finally关键字finally关键字用于编写一段无论是否发生异常都会被执行的代码块。
它的语法如下:```try {// 可能会抛出异常的代码} catch (Exception e) {// 异常处理代码} finally {// 无论是否发生异常都会执行的代码}```在try-catch语句中使用finally块,可以确保无论是否发生异常,finally块中的代码都会被执行。
通常,finally块中会释放资源或者进行一些清理操作。
以上是Java中三种常见的异常处理方法。
在编写程序时,我们应该根据具体情况选择合适的方法处理异常,以保证程序的健壮性和稳定性。
exception方法
Java中的异常是面向对象的一个概念,通过它可以处理运行时产生
的错误和异常状态。
它可以在运行过程中检测错误和异常,并采取必要的
措施来处理它们,这样就不会产生负面影响。
一般来说,Java的异常操作可以分为两类:可检查异常和运行时异常。
可检查异常必须捕获并处理,以保证程序的正常运行,而运行时异常
只需要在触发时出现提示信息即可。
当发生异常时,第一步要做的就是捕获它,这样才能确定异常的类型,从而根据不同的异常类型采取不同的处理方式。
Java中有两种捕获异常
的方式,一种是使用try-catch语句,另一种是使用throws关键字。
try-catch语句用于捕获异常并处理异常。
它有两个语句块,第一个
是try语句块,用于放置可能出现异常的代码,第二个是catch语句块,
用于捕获抛出的异常,同时可以对该异常进行处理。
另一种捕获异常的方法就是使用throws关键字。
throws关键字可以
将可抛出的异常(即可检查异常)声明在方法名称之后,这样,调用方法
的程序就需要创建try-catch块来捕获这些异常。
如果没有使用try-
catch块捕获这些异常,则会调用throws子句声明的方法的调用者捕获
该异常。
如果发生运行时异常,则不需要捕获此异常,因为在程序运行过程中,运行时异常是不能被捕获的。
一般面试中java Exception(runtimeException)是必会被问到的问题常见的异常列出四五种,是基本要求。
更多的。
需要注意积累了常见的几种如下:NullPointerException-空指针引用异常ClassCastException-类型强制转换异常。
IllegalArgumentException-传递非法参数异常。
ArithmeticException-算术运算异常ArrayStoreException-向数组中存放与声明类型不兼容对象异常IndexOutOfBoundsException-下标越界异常NegativeArraySizeException-创建一个大小为负数的数组错误异常NumberFormatException-数字格式异常SecurityException-安全异常UnsupportedOperationException-不支持的操作异常算术异常类:ArithmeticExecption空指针异常类:NullPointerException类型强制转换异常:ClassCastException数组负下标异常:NegativeArrayException数组下标越界异常:ArrayIndexOutOfBoundsException违背安全原则异常:SecturityException文件已结束异常:EOFException文件未找到异常:FileNotFoundException字符串转换为数字异常:NumberFormatException操作数据库异常:SQLException输入输出异常:IOException方法未找到异常:NoSuchMethodExceptionng.AbstractMethodError抽象方法错误。
当应用试图调用抽象方法时抛出。
ng.AssertionError断言错。
用来指示一个断言失败的情况。
ng.ClassCircularityError类循环依赖错误。
异常Java的异常处理涉及到5个关键字:try,catch,throw,throws,finally.异常处理流程由try,catch和finally3个代码块组成。
其中try代码块包含了可能发生异常的程序代码:catch代码块紧跟在try代码块后面,用来捕获并处理异常;finally代码块用于释放被占用的相关资源。
一.异常是java提供的处理程序中运行时错误的一种机制java程序在执行过程中如果出现异常,会生成一个异常类实例,该实例封装了异常的信息交给java运行时系统,这一过程叫抛出异常二.异常体系结构Error(系统的内部错误是程序员无法控制的错误,虚拟机错误)Object--Throwable(一般的Exception必须要显示的捕获)Exception(程序员可以控制的错误)RuntimeException(运行时异常,不需要显示捕获)只要是Throwable的实例或者它的子类的实例都能被throws(方法中),也能被throw(代码块中)Exception我能处理的Error系统断电,无法处理*RuntimeException--经常出的错误(可以逮它可以不逮它,比如一些小错误)try{ ...}catch(AtimeticException e){ ...}catch(Exception e){ ...} finally{}finally代码块不管try 语句块中是否抛出异常都回去执行。
throws 抛出异常,用于编译能通过,并没有真正处理异常throws 主要用于抛出检测异常。
throws 用于方法/构造的{ 前面,参数列表的后面(参数列表)[throws XXException] {一个方法可能会出现多种异常,throws子句允许声明抛出多个异常Public void method() throws SQLException,IOException{…}能处理的异常用try/catch,不能处理的(交其他人处理的)异常用throwsthrow 可以由程序员抛出异常对象,是一个语句。
Java常见异常(RuntimeException)详细介绍并总结本⽂重在Java中异常机制的⼀些概念。
写本⽂的⽬的在于⽅便我很长时间后若是忘了这些东西可以通过这篇⽂章迅速回忆起来。
1. 异常机制1.1 异常机制是指当程序出现错误后,程序如何处理。
具体来说,异常机制提供了程序退出的安全通道。
当出现错误后,程序执⾏的流程发⽣改变,程序的控制权转移到异常处理器。
1.2 传统的处理异常的办法是,函数返回⼀个特殊的结果来表⽰出现异常(通常这个特殊结果是⼤家约定俗称的),调⽤该函数的程序负责检查并分析函数返回的结果。
这样做有如下的弊端:例如函数返回-1代表出现异常,但是如果函数确实要返回-1这个正确的值时就会出现混淆;可读性降低,将程序代码与处理异常的代码混爹在⼀起;由调⽤函数的程序来分析错误,这就要求客户程序员对库函数有很深的了解。
1.3 异常处理的流程1.3.1 遇到错误,⽅法⽴即结束,并不返回⼀个值;同时,抛出⼀个异常对象1.3.2 调⽤该⽅法的程序也不会继续执⾏下去,⽽是搜索⼀个可以处理该异常的异常处理器,并执⾏其中的代码2 异常的分类2.1 异常的分类2.1.1 异常的继承结构:基类为Throwable,Error和Exception继承Throwable,RuntimeException和IOException等继承Exception,具体的RuntimeException继承RuntimeException。
2.1.2 Error和RuntimeException及其⼦类成为未检查异常(unchecked),其它异常成为已检查异常(checked)。
2.2 每个类型的异常的特点2.2.1 Error体系 Error类体系描述了Java运⾏系统中的内部错误以及资源耗尽的情形。
应⽤程序不应该抛出这种类型的对象(⼀般是由虚拟机抛出)。
如果出现这种错误,除了尽⼒使程序安全退出外,在其他⽅⾯是⽆能为⼒的。
ng.NullPointerException原因是:有空指针,有地址没赋值2.Exception in thread "main" ng.ArithmeticException: / by zero原因是除数是03.ArrayIndexOutOfBoundsException原因是:数组越界ng.NumberFormatException原因是:数字格式化有问题5.Unhandled exception type Exception原因是:没有进行异常处理6.进行国际化操作的时候遇到这样的错误:Exception in thread "main" java.util.MissingResourceException: Can't find bundle for base name Message, locale zh_CN答:因为在命令提示符中,是没有错误的解决方法是:在myeclipse中,会出现这个错误java国际化之Can't find bundle for base name1.初步学习最近在学习ResourseBundle时遇到了“Can't find bundle for base name ”这个错误搞了很久才解决了。
原因就是类路径问题要将属性文件放在类路径中!百度里很多都是教程但没有涉及到解决方法!2.中文显示:测试文件java 代码package com.lht.ResourseBundleStudy;import java.util.ResourceBundle;public class ResourseBundleDemo {public static void main(String[] args) {ResourceBundle resource = ResourceBundle.getBundle("test");System.out.print(resource.getString("msg0") + "!");System.out.println(resource.getString("msg1") + "!"); }}test.propertiesmsg0="Hello World"msg1="da jia hao"开始自己测试的时候:将属性文件放在bin/下也试过也不行无赖中就在google中搜索了一下终于在sun的java论坛(/thread.jspa?threadID=660477&messageID=4231534)中找到了线索下面是帖子的内容:I've solved the problem the best way possible. Basically what i've done is added a new class folder named config to the project home dir. Then i added this classfolder to the classpath in project properties. After doing all of this you only need to reference the properties file by "Email".Hope this helps anyone else who is having similiar problems.基本意思就是在src下建立classes(名字无所谓)文件夹将属性文件存放在下面,然后将这个文件夹加入类路径中!运行就可以了:加入类路径的方法:你的工程文件夹->properties->选择Libraries选项卡->Add Class Folder 将刚才建立的文件夹加入就可以了!结果如下:"Hello World"!"da jia hao";!2.中文显示在classes目录下建立message_CH.properties内容如下:ms0="大家好"同样用上面的测试文件!结果如下:"?ó????"!乱码怎么回事啊!在百度里搜索后找到了答案有以为网友写的很清楚:/3885062.html 下面引用如下:原理Property文件中,使用的编码方式根据机器本身的设置可能是GBK或者UTF-8。
JAVA常见异常1. ng.nullpointerexception这个异常大家肯定都经常遇到,异常的解释是"程序遇上了空指针",简单地说就是调用了未经初始化的对象或者是不存在的对象,这个错误经常出现在创建图片,调用数组这些操作中,比如图片未经初始化,或者图片创建时的路径错误等等。
对数组操作中出现空指针,很多情况下是一些刚开始学习编程的朋友常犯的错误,即把数组的初始化和数组元素的初始化混淆起来了。
数组的初始化是对数组分配需要的空间,而初始化后的数组,其中的元素并没有实例化,依然是空的,所以还需要对每个元素都进行初始化(如果要调用的话)2. ng.classnotfoundexception这个异常是很多原本在jb等开发环境中开发的程序员,把jb下的程序包放在wtk下编译经常出现的问题,异常的解释是"指定的类不存在",这里主要考虑一下类的名称和路径是否正确即可,如果是在jb下做的程序包,一般都是默认加上package的,所以转到wtk下后要注意把package的路径加上。
3. ng.arithmeticexception这个异常的解释是"数学运算异常",比如程序中出现了除以零这样的运算就会出这样的异常,对这种异常,大家就要好好检查一下自己程序中涉及到数学运算的地方,公式是不是有不妥了。
4. ng.arrayindexoutofboundsexception这个异常相信很多朋友也经常遇到过,异常的解释是"数组下标越界",现在程序中大多都有对数组的操作,因此在调用数组的时候一定要认真检查,看自己调用的下标是不是超出了数组的范围,一般来说,显示(即直接用常数当下标)调用不太容易出这样的错,但隐式(即用变量表示下标)调用就经常出错了,还有一种情况,是程序中定义的数组的长度是通过某些特定方法决定的,不是事先声明的,这个时候,最好先查看一下数组的length,以免出现这个异常。
异常处理1、为什么要引入异常处理机制我们的程序在编译或运行时可能会出问题,当出现问题的时候程序就死掉了,这样的程序健壮性不好。
因此在JAVA中我们引入了异常处理机制,既保证能及时发现问题并加以纠正,又能保证程序不死掉。
JAVA中保证程序健壮性的方式有三种:垃圾回收机制(保证不会发生内存泄露)弃用指针(保证不能直接对底层进行操作)异常处理机制(保证程序不会因发生异常而死掉)2、什么是异常处理机制2.1、异常的定义程序问题的分类:错误(Error):严重的错误,无法通过修改代码来处理。
如JVM运行失败、线程池出错导致JVM无法正确运行。
异常(Exception):异常表示程序执行过程中出现的不正常的现象,可以通过修改代码来进行弥补。
⏹ 异常的分类:◆ 运行时异常(unchecked):运行时异常都是RuntimeException类及其子类异常,如NullPointerException、IndexOutOfBoundsException等,这些异常是不检查异常,程序中可以选择捕获处理,也可以不处理。
这些异常一般是由程序逻辑错误引起的,程序应该从逻辑角度尽可能避免这类异常的发生。
◆ 编译时异常(checked):编译时异常是RuntimeException以外的异常,类型上都属于Exception类及其子类。
从程序语法角度讲是必须进行处理的异常,如果不处理,程序就不能编译通过。
如IOException、SQLException等以及用户自定义的Exception异常,一般情况下不自定义检查异常。
⏹ 异常处理的顺序:◆ 引发异常(检测异常情况并生成异常的过程叫引发异常)◆ 捕获异常(当异常被引发时,可被处理程序捕获)◆ 处理异常(上面的两个过程总称为处理异常)2.2、异常的捕获和处理机制Java异常处理涉及到五个关键字,分别是:try、catch、finally、throw、throws 一个异常处理块的通常语法形式:Try{//可能引发异常的语句}Catch(ExceptionType1 ex){//获得此类异常信息并处理异常的代码}Catch(ExceptionType2 ex){//获得此类异常信息并处理异常的代码}(注意:Catch块的放置顺序,捕获子类异常放前面,捕获父类异常放后面)…………Finally{//一般为释放资源的语句}⏹ 以上语法有三个代码块:try语句块,表示要尝试运行代码,try语句块中代码受异常监控,其中代码发生异常时,会抛出异常对象。
exception的方法Exception的方法Exception是Java中一个非常重要的类,它是所有异常类的父类。
在Java中,异常是一种程序运行过程中的错误或异常情况,而Exception类提供了一系列的方法来处理这些异常。
本文将介绍Exception类中常用的方法。
1. getMessage()getMessage()方法返回异常的详细描述信息。
通常情况下,该方法会返回异常类中定义的错误信息,用于帮助开发者迅速定位错误的原因。
2. printStackTrace()printStackTrace()方法将异常的跟踪栈信息打印到标准错误流。
这些跟踪信息包括异常的类型、异常出现的位置以及调用栈信息,对于定位和调试异常非常有帮助。
3. toString()toString()方法返回异常对象的字符串表示形式。
通常情况下,该方法会返回异常类的名称和详细描述信息。
4. getCause()getCause()方法返回导致当前异常的原因。
如果当前异常是由其他异常引发的,那么getCause()方法将返回原因异常。
5. getLocalizedMessage()getLocalizedMessage()方法返回异常的本地化描述信息。
该方法可以根据不同的语言环境返回不同的描述信息,方便国际化处理。
6. fillInStackTrace()fillInStackTrace()方法重新填充异常的跟踪栈信息。
通常情况下,该方法会在异常被抛出时自动调用,重新生成跟踪栈信息。
7. equals()equals()方法判断两个异常对象是否相等。
通常情况下,异常对象的相等性是根据异常类的类型和详细描述信息来确定的。
8. hashCode()hashCode()方法返回异常对象的哈希码。
通常情况下,哈希码是根据异常类的类型和详细描述信息计算得出的。
9. getStackTrace()getStackTrace()方法返回异常对象的跟踪栈信息。
exception的种类
exception的种类有很多,主要包括以下几种:
1. RuntimeException:这是一种运行时异常,通常被认为是程序员的错误,而不是程序本身的问题。
2. IOException:这种异常通常会在文件或网络通信等输入/输出操作中被抛出,表示操作无法继续。
3. ClassNotFoundException:这种异常表示在尝试加载类时找不到该类。
4. NullPointerException:这种异常表示尝试对空对象进行操作,通常是程序员的错误。
5. ArrayIndexOutOfBoundsException:这种异常表示尝试访问数组中不存在的索引。
6. ArithmeticException:这种异常表示尝试进行除以零或其他算术运算错误。
7. IllegalArgumentException:这种异常表示传递给方法的参数不正确。
8. InterruptedException:这种异常表示线程在等待或睡眠时被中断。
9. SecurityException:这种异常表示安全限制被违反,例如尝试访问受限资源。
10. ClassCastException:这种异常表示尝试将对象强制转换为不兼容的类型。
ioexception类型摘要:1.IOException类型简介2.IOException的特点与用途3.处理IOException的方法4.示例代码正文:IOException类型是Java编程中常见的一种异常,它表示在执行I/O操作时发生了错误。
这种异常通常用于处理文件读写、网络通信等场景中出现的错误。
本文将详细介绍IOException类型,包括其特点、用途以及如何处理和抛出这种异常。
1.IOException类型简介IOException是Java异常体系中的一个重要成员,它继承自Exception 类。
在Java编程中,IOException主要用于处理输入输出操作中的错误,包括文件操作、网络连接、数据库操作等。
当程序在执行这些操作时遇到错误,例如文件未找到、磁盘空间不足、网络连接中断等,都会抛出IOException。
2.IOException的特点与用途IOException具有以下特点:- IOException是运行时异常,这意味着它在程序运行过程中被捕获,而不是编译时。
- IOException是不可继承的,因此不能被其他类继承。
- IOException通常包含详细的错误信息,有助于程序员定位问题。
在实际编程中,处理IOException的主要目的是在出现错误时,能够及时停止程序的执行,并进行相应的提示或日志记录。
这有助于提高程序的健壮性和可维护性。
3.处理IOException的方法处理IOException的方法主要包括以下几种:- 使用try-catch语句捕获异常:在可能出现IOException的代码段前加上try关键字,并在catch块中处理异常。
这样,当异常发生时,程序将跳转到catch块执行相应的处理逻辑。
- 自定义异常处理类:创建一个继承自IOException的子类,并在其中添加额外的错误信息或处理逻辑。
这样,当程序抛出该异常时,可以根据需要进行更细致的处理。
exception用法什么是exception?在计算机编程中,exception(异常)是指在程序运行过程中出现的错误或异常情况。
当程序执行到某个地方时,如果遇到了错误或者无法正常处理的情况,就会抛出一个异常。
异常可以是由程序员主动触发,也可以是由系统自动触发。
为什么要使用exception?异常处理机制是现代编程语言中的一个重要特性,其目的是提高程序的稳定性和可靠性。
通过使用异常处理机制,可以在程序出现错误时,及时捕获并处理异常情况,避免程序崩溃或产生未知结果。
通过合理地使用异常,可以提高代码的可读性和可维护性,使程序更加健壮和可靠。
如何使用exception?在编程中,使用异常需要遵循一定的规范和步骤。
首先,需要明确应该捕获哪些异常。
通常情况下,应该捕获那些可能导致程序出错或无法正常处理的异常,例如除零异常、空指针异常等。
接下来,需要在可能发生异常的地方添加异常处理的代码。
可以使用try-catch语句来捕获异常。
在try 块中,编写可能会产生异常的代码,而在catch块中,根据需要进行异常处理的代码。
当try块中的代码出现异常时,程序会跳转到对应的catch 块继续执行异常处理的代码。
此外,还可以使用finally块,该块中的代码不论是否发生异常都会执行。
finally块通常用于释放资源或进行清理操作。
除了try-catch-finally语句,还可以使用throw语句来主动抛出异常。
当程序中的某个条件不满足时,可以使用throw语句抛出一个异常对象。
throw语句将异常对象传递给调用者,然后由调用者决定如何处理该异常。
在处理异常时,应该根据具体情况进行合适的异常处理。
可以选择捕获异常后直接处理,也可以选择包装异常后再抛出。
包装异常通常用于在不损失异常信息的情况下将异常传递给上层调用者。
此外,在进行异常处理时,应该遵循“避免过早优化”的原则,尽量不要过度使用异常处理语句,以免降低代码的可读性和性能。
Exception类Exception类称为非致命性类,它代表了另一种异常。
发生该异常的程序,可以通过捕获处理后正常运行,保持程序的可读性及可靠性。
在开发Java程序过程中进行的异常处理,主要就是针对该类及其子类的异常处理。
对程序中可能发生的该类异常,应该尽可能进行处理,以保证程序在运行时,能够顺利执行,而不应该在异常发生后终止程序。
Exception类又根据错误发生的原因分为两种异常类型:RuntimeException异常和Runtime Exception之外的异常。
1.RuntimeException异常RuntimeException异常也称为不检查异常(unchecked exception),是程序员编写了错误的程序导致,修改了该错误后,程序就可以继续执行。
例如,学校制定校规,若有学生违反了校规,就相当于发生了一个RuntimeException异常。
在程序中发生该异常的情况包括除数为0的运算、数组下标越界、对没有引用任何对象的变量进行操作等。
当RuntimeExeption 类或其子类所描述的异常发生后,可以不通过try-catch、throws语句捕获或抛出,在编译时是可以通过的,只是在运行时由Java虚拟机来抛出。
Java中提供的常见的RuntimeExc eption异常如表1所示,这些异常类都是Runtime Exception类的子类,表示了具体的一种不检查异常类型。
表1 RuntimeException异常类列表●●ArithmeticException类该类用来描述算术异常,例如在除法或求余运算中规定,除数不能为0,所以当除数为0时,则Java虚拟机抛出该异常。
例如:int num=9%0; //除数为0,抛出ArithmeticException异常●●NullPointerException类用来描述空指针异常,当引用变量值为null,试图通过“.”操作符对其进行访问时,抛出该异常。
Java异常异常Exception和Error区别1)Exception是程序正常运行中,可以预料的以外情况,可以被捕获进行相应处理;Error是正常情况下,不大可能出现的情况,绝大部分Error会导致程序处于非正常、不可恢复状态,如OutOfMemoryError等无法捕获处理。
2)Exception分为可检查异常(checked)和不检查异常(unchecked),可检查异常在程序中必须显式进行捕获处理,是编译期检查的一部分。
不检查异常是运行时异常,如NullPointerException、ArrayIndexOutOfBoundsException等,属于编码可避免的逻辑错误,不会编译期强求。
3)Exception和Error都继承Throwable。
NoClassDefFoundError和ClassNotFoundException区别NoClassDefFoundError是一个Error类,是指一个class在编译时存在,但在运行时找不到class文件。
ClassNotFoundException是一个Exception类,使用类似Class.forName()等方法时进行的checked exception。
checked exception和unchecked exception区别受检查异常1)checked exception是受检查异常,Java代码在编译过程中,若受检查异常未被catch或throws关键字处理,则无法通过编译。
2)除了RuntimeException及其子类,其他的Exception类和其子类都属于受检查异常。
3)常见的受检查异常:如IO相关异常、SQLException、ClassNotFoundException。
不受检查异常(运行时异常)1)unchecke exception是不受检查异常,Java代码在编译过程中,即使不处理该异常,也能够通过编译。
Java⾥的异常(Exception)详解作为⼀位初学者, 本屌也没有能⼒对异常谈得很深⼊. 只不过⾥关于Exception的东西实在是很多. 所以这篇⽂章很长就是了..⼀, 什么是java⾥的异常由于java是c\c++ 发展⽽来的, ⾸先我们先看看c语⾔⾥的错误.1.1 c语⾔⾥的错误我们实现1个程序的过程包括, 代码编写, 编译代码成为程序, 执⾏程序..其中⼤部分常见的语法错误都会被编译代码这样部过滤掉. 但是即使通过了编译. 执⾏程序这⼀步可能还是会有错误.原因很多, 例如常见的除数为0, 内存溢出(数组的index超出界限), 或者内存被其他程序修改等.最简单的例⼦:[java]1. #include <stdio.h>2.3. int f(int a, int b){4. return a/b;5. }6.7. int main(){8. int i = f(8,0);9. printf("i is %d\n",i);10. return 0;11. }上⾯的例⼦编译时是⽆错的, 但是⼀旦执⾏就会提⽰吐核错误了.c语⾔⾥对这种执⾏时出现的错误是⽆能为⼒的, ⼀旦出错就会整个程序崩溃, 就不会在继续执⾏下⾯的代码.⽽且很多时候出错信息很少, 让你⽆法判断出错的原因和地⽅, 只能⼀步步⼩⼼debug...所以很多⽤c写的程序有时会出现⾮法关闭的现象.解决⽅法只能是在代码⾥对可能出错的地⽅添加if 判断.例如f()函数⾥可以对b进⾏判断, 如果是0就不执⾏.1.2 java⾥运⾏时出现的错误java⾥编译器对代码的规范性⽐c严格得多. 但是即使如此, 通过编译的java程序有时也很难避免执⾏时出错.例如, 将上⾯的c程序改编成java程序:[java]1. package Exception_kng;2.3. class Exp1{4. public int f(int a, int b){5. return a/b;6. }7. }8.9. public class Expt_1{10. public static void g(){11. Exp1 e = new Exp1();12. int i = e.f(8,0);13. System.out.printf("i is %d\n", i);14. }15. }运⾏时⼀样会出错, 下⾯是出错信息:[java]1. [java] Caused by: ng.ArithmeticException: / by zero2. [java] at Exception_kng.Exp1.f(Expt_1.java:5)3. [java] at Exception_kng.Expt_1.g(Expt_1.java:12)4. [java] at Enter_1.main(Enter_1.java:31)但是可以见到, java告诉你出错的类型: 运算错误(ArithmeticExcetion), 出错信息和出错的类与⽂件⾏数输出, ⽅便你调试. jvm虚拟机是会对错误作出⼀定的处理的.所以可以简单地将java⾥的异常理解成java运⾏时出现的错误, 异常机制就是对这种错误进⾏处理的机制.1.3 java异常的定义实际上, 当java程序执⾏时出现错误时, jvm会把执⾏时出错的信息(例如出错原因, 类型, 位置) 收集,然后打包成为1个对象(object), 程序员可以对这种对象进⾏处理. 这种对象就是所谓的异常.可能出现的异常的代码并不是肯定会出现异常, 取决于执⾏环境和数据.!⼆, java⾥的异常的分类.见下图:Throwable/ \Error Exception/ / \xxxxxx xxxxxx RuntimeException/ \xxxxxx ArithmeticException上图的所有对象都是类.Throwable 代表是可抛出的.Error 代表的是严重错误, 这种错误程序员⽆法进⾏处理, 例如操作系统崩溃, jvm出错, 动态链接库失败等. Error并不是异常, 不是本⽂的重点.Exception 代表的就是异常了. 它下⾯很多派⽣类, 其中它的派⽣类也分两种, ⼀种是RuntimeException(运⾏时异常), 其他的都是⾮运⾏时异常RuntimeException 包括除数为0, 数组下标超界等. 运⾏时异常的派⽣类有很多, 其产⽣频率较⾼. 它的派⽣类可以由程序处理或者抛给(throw) 给jvm处理. 例如上⾯的例⼦就是抛给了jvm处理, jvm把程序中断执⾏, 并把错误信息输出到终端上.⾮RuntimeExcption 这种异常属于Excepion的派⽣类(上⾯红⾊的xxx), 但是不是RuntimeException的派⽣类, 这种异常必须由程序员⼿动处理,否则不通过编译.ArithmeticExcpetion 算术异常, 它是RuntimeException的派⽣类, 所以程序员不⼿动处理也通过编译, 只不过出错时会被jvm处理.三, java⾥对异常的处理java⾥对异常的处理有三种.3.1 程序猿对有可能出现的异常使⽤try catch处理.例如我们将上⾯的例⼦改动⼀下:[java]1. package Exception_kng;2.3. class Exp2{4. public int f(int a, int b){5. int i = 0;6. try{7. i = a/b;8. }9. catch(Exception e){10. System.out.printf("Exception occurs!!\n");11. System.out.println(e.getMessage()); //print the root cause12. System.out.printf("===========================\n");13. e.printStackTrace(); //print the info of function stuck.14. }15.16. return i;17. }18. }19.20. public class Expt_2{21. public static void g(){22. Exp2 ex = new Exp2();23. int i = ex.f(8,0); //call f()24. System.out.printf("i is %d\n", i); //successfully executed25. }26. }在f()函数中对可能出现的异常的代码进⾏try catch处理后, 程序会执⾏catch⾥的代码. ⽽且不会中断整个程序, 继续执⾏try catch后⾯的代码.程序执⾏输出:[java]1. [java] Exception occurs!!2. [java] / by zero3. [java] ===========================4. [java] ng.ArithmeticException: / by zero5. [java] at Exception_kng.Exp2.f(Expt_2.java:7)6. [java] at Exception_kng.Expt_2.g(Expt_2.java:23)7. [java] at Enter_1.main(Enter_1.java:31)8. [java] i is 0注意最终也执⾏了g()函数中的最后⼀条语句, 输出了i的值.也就是说try catch处理后并不会终⽌程序, 令程序即使出现了错误, 也可以对错误进⾏⼀定的处理后继续执⾏. 这就是java异常机制⽐c语⾔安全的地⽅.下⾯会详细讲解 try catch.注:getMessage() ⽅法: Exception类的⽅法之⼀, 返回异常的原因, 上⾯的 / by zero 就是这个⽅法输出的.printStackTrace(): Exception类的⽅法之⼀, 在屏幕输出函数栈信息, 也就是异常出现的地⽅.3.2 函数⾥并不处理异常, 使⽤throw or throws 关键字把可能出现的异常抛给调⽤该函数的上级函数处理.例如我在f()函数中不想处理可能出现的异常, 想把它抛出上级函数处理:下⾯是个例⼦:[java]1. package Exception_kng;2.3. class Exp3{4. public int f(int a, int b){5. if (0 == b){6. throw new ArithmeticException("Shit !!! / by zero!");7.8. }9.10. return a/b;11. }12. }13.14. public class Expt_3{15. public static void g() throws ArithmeticException{16. Exp3 ex = new Exp3();17. int i = 22;18. i = ex.f(8,0); //throw excetpion19. System.out.printf("i is %d\n", i); //failed executed20. System.out.printf("g() is done!!\n"); //failed executed21. }22.23. public static void h(){24. try{25. g();26. }catch(ArithmeticException e){27. System.out.printf("Exception occurs!!\n");28. System.out.println(e.getMessage()); //print the root cause29. System.out.printf("===========================\n");30. e.printStackTrace(); //print the info of function stuck.31. }32.33. System.out.printf("h() is done!!\n"); //successfully executed34. }35. }可以见到f() 加了个条件判断, 如果参数b = 0, 使⽤throw 直接⼿动抛出1个异常. 让调⽤它的函数处理.g()调⽤f()函数, 预见到f()可能有异常, 但是也不想处理, 使⽤throws 关键字告诉调⽤它的函数本函数有可能抛出这种异常. // 注, 这⾥的throws 对程序并没有实质的影响.h()调⽤g(), 简单g()定义的throws, ⽤try catch在本函数进⾏处理.输出:[java]1. [java] Exception occurs!!2. [java] Shit !!! / by zero!3. [java] ===========================4. [java] ng.ArithmeticException: Shit !!! / by zero!5. [java] at Exception_kng.Exp3.f(Expt_3.java:6)6. [java] at Exception_kng.Expt_3.g(Expt_3.java:18)7. [java] at Exception_kng.Expt_3.h(Expt_3.java:25)8. [java] at Enter_1.main(Enter_1.java:31)9. [java] h() is done!!注意这个程序没有执⾏g() 最后的代码.throw 和 throws 后⾯也会详细讲解.3.3 交给jvm虚拟机处理假如上⾯的例⼦h() 也不处理怎么办? 就如1.2 的例⼦, 会抛给jvm处理.但是这种情况只适⽤于RuntimeExecption及其派⽣类.jvm怎么处理呢, 就是中断整个程序, 并把异常信息输出到屏幕上.实际上, 当java程序的1个函数抛出异常时,⾸先会检查当前函数有没有try catch处理, 如果⽆检查上⼀级函数有⽆try..catch处理....这样在函数栈⾥⼀级⼀级向上检查, 如果直⾄main函数都⽆try..catch, 则抛给jvm..项⽬中强烈建议尽量⼿动处理, 不要把异常交给jvm.四,Try catch finally 的处理机制.这⾥开始详解try catch finally了.语法是这样的.try{可能出异常的若⼲⾏代码;}catch(ExceptionName1 e){产⽣ExceptionName 1的处理代码;}catch(ExceptionName2 e){产⽣ExceptionName 2的处理代码;}...finally{⽆论如何, 最终肯定会执⾏的代码}4.1 try catch finally的执⾏路线.下⾯⽤个例⼦来说明:[java]1. try{2. f();3. ff();4. }5. catch(ArithmeticException e){6. g();7. }8. catch(IOException e){9. gg();10. }11. catch(AuthorizedException e){12. ggg();13. }14. finally{15. h();16. }17.18. k();4.1.1 当try⾥⾯的f()抛出了IOException当f()抛出了异常, 那么ff()就不会执⾏了. 程序会尝试捕捉异常.⾸先捕捉ArithmeticException, 捕捉失败.接下来捕捉IOException, 捕捉成功, 执⾏gg();⼀旦捕捉到⼀个异常, 不会再尝试捕捉其他异常, 直接执⾏finally⾥的h();执⾏后⾯的函数k().也就是说路线是:f() -> gg() -> h() -> k()有2点要注意的.1. f()函数极有可能未完整执⾏, 因为它抛出了异常, 抛出异常的语句执⾏失败, 之后的语句放弃执⾏.2. try{} ⾥⾯, f()之后的语句, 例如ff()放弃执⾏.4.1.2 没有任何异常抛出这种情况很简单, 就是try{}⾥⾯的代码被完整执⾏, 因为没有抛出任何异常, 就不会尝试执⾏catch⾥的部分, 直接到finally部分了.路线是:f() -> ff() -> h() -> k()4.2 如何确定要捕捉的异常名字.也许有⼈会问, 我们怎么知道到底会抛出什么异常?下⾯有3个解决⽅案.1.看代码凭经验, 例如看到1段除法的代码, 则有可能抛出算术异常.2.在catch的括号⾥写上Exception e, 毕竟Exception 是所有其他异常的超类, 这⾥涉及多态的知识, ⾄于什么是多态可以看看本⼈的另⼀篇⽂章.3. 观察被调⽤函数的函数定义, 如果有throws后缀, 则可以尝试捕捉throws 后缀抛出的异常4.3 为什么需要finally包括我在内很多⼈会觉得finally语句简直多勾余, 既然是否捕捉到异常都会执⾏, 上⾯那个例⼦⾥的h()为什么不跟下⾯的k() 写在⼀起呢.上⾯的例⼦的确看不出区别.但下⾯两种情况下就体现了finally独特的重要性.4.3.1 抛出了1个异常, 但是没有被任何catch⼦句捕捉成功.例如try⾥⾯抛出了1个A异常, 但是只有后⾯只有捕捉B异常, 和C异常的⼦句.这种情况下, 程序直接执⾏finally{}⾥的⼦句, 然后中断当前函数, 把异常抛给上⼀级函数, 所以当前函数finally后⾯的语句不会被执⾏.例⼦:[java]1. package Exception_kng;2.3. import .*;4. import java.io.*;5.6. class Exp4{7. public int f(int a, int b) throws IOException, BindException{8. return a/b;9. }10. }11.12. public class Expt_4{13. public static void g(){14. Exp4 ex = new Exp4();15. int i = 22;16. try{17. System.out.printf("g() : try!!\n"); //failed18. i = ex.f(8,0); //call f()19. }20. catch(BindException e){21. System.out.printf("g() : BindException!!\n"); //failed22. }23. catch(IOException e){24. System.out.printf("g() : IOException!!\n"); //failed25. }26. finally{27. System.out.printf("g() : finaly!!\n"); //successfully executed28. }29. System.out.printf("g() is done!!\n"); //failed30. }31.32. public static void h(){33. try{34. g();35. }catch(ArithmeticException e){36. System.out.printf("Exception occurs!!\n");37. System.out.println(e.getMessage()); //print the root cause38. System.out.printf("===========================\n");39. e.printStackTrace(); //print the info of function stuck.40. }41.42. System.out.printf("h() is done!!\n"); //successfully executed43. }44. }我所说的情况, 就在上⾯例⼦⾥的g()函数, g()函数⾥尝试捕捉两个异常, 但是抛出了第3个异常(ArithmeticException 算术异常).所以这个异常会中断g()的执⾏, 因为没有被捕捉到, 然后抛给调⽤g()的 h()函数处理, ⽽在h()捕捉到了, 所以h()函数是能完整执⾏的.也就是说g()⾥的[java]1. System.out.printf("g() is done!!\n"); //failed执⾏失败⽽h()⾥的[java]1. System.out.printf("h() is done!!\n"); //successfully executed执⾏成功但是⽆论如何, g()⾥的finally{}部分还是被执⾏了执⾏结果如下:[java]1. [java] g() : try!!2. [java] g() : finaly!!3. [java] Exception occurs!!4. [java] / by zero5. [java] ===========================6. [java] ng.ArithmeticException: / by zero7. [java] at Exception_kng.Exp4.f(Expt_4.java:8)8. [java] at Exception_kng.Expt_4.g(Expt_4.java:18)9. [java] at Exception_kng.Expt_4.h(Expt_4.java:34)10. [java] at Enter_1.main(Enter_1.java:31)11. [java] h() is done!!这种情况是1中编程的低级错误, 在项⽬中是不允许出现.避免⽅法也⼗分简单, 在catch⼦句集的最后增加1个catch(Exception e)就ok, 因为Exception是所有异常的超类, 只要有异常抛出, 则肯定会捕捉到.4.3.2 在catch⼦句内有return⼦句.下⾯例⼦:[java]1. try{2. f();3. ff();4. }5. catch(ArithException e){6. g();7. return j();8. }9. catch(IOException e){10. gg();11. return j();12. }13. catch(AuthorizedException e){14. ggg();15. return j();16. }17. finally{18. h();19. }20.21. k();假如在f()函数抛出了IOExcepion 异常被捕捉到.那么执⾏路线就是f() -> gg() -> j() -> h() -> 上⼀级function也就说, 这种情况下finally⾥的⼦句会在return回上⼀级function前执⾏. ⽽后⾯的k()就被放弃了.4.3.3 finally作⽤⼩结.可以看出, finally⾥的语句, ⽆论如何都会被执⾏.⾄有两种情况除外, ⼀是断电, ⼆是exit函数.在项⽬中, 我们⼀般在finally编写⼀些释放资源的动作, 例如初始化公共变量. 关闭connections, 关闭⽂件等.4.4 try catch finally⾥⼀些要注意的问题.4.4.1 ⽆论如何最多只有1个catch被执⾏这个上⾯提到过了, ⼀旦捕捉到1个异常, 就不会尝试捕捉其他异常.如果try⾥⾯的⼀段代码可能抛出3种异常A B C,⾸先看它先抛出哪个异常, 如果先抛出A, 如果捕捉到A, 那么就执⾏catch(A)⾥的代码. 然后finally.. B和C就没有机会再抛出了.如果捕捉不到A, 就执⾏finally{}⾥的语句后中断当前函数, 抛给上⼀级函数...(应该避免)4.4.2 有可能所有catch都没有被执⾏两种情况, 1就是没有异常抛出, 另⼀种就是抛出了异常但是没有捕捉不到(应该避免)4.4.3 先捕捉⼦类异常, 再捕捉⽗类异常, 否则编译失败加⼊try ⾥⾯尝试捕捉两个异常, 1个是A, 1个是B, 但是A是B的⽗类.这种情况下, 应该把catch(B)写在catch(A)前⾯.原因也很简单, 加⼊把catch(A)写在前⾯, 因为多态的存在, 即使抛出了B异常, 也会被catch(A)捕捉, 后⾯的catch(B)就没有意义了.也就是说如果捕捉Exception这个异常基类, 应该放在最后的catch⾥, 项⽬中也强烈建议这么做, 可以避免上述4.3.1的情况出现.4.4.4 catch与catch之间不能有任何代码.这个没什么好说的. 语法规则4.4.5 finally⾥不能访问catch⾥捕捉的异常对象e每1个异常对象只能由catch它的catch⼦句⾥访问.4.4.6 try⾥⾯的定义变量不能在try外⾯使⽤.跟if类似, 不多说了.4.4.7 try catch finally可以嵌套使⽤.这个也不难理解..五, throw 和throws的机制和⽤法.下⾯开始详讲异常另⼀种处理⽅法throw 和 throws了.注意的是, 这两种⽤法都没有真正的处理异常, 真正处理的异常⽅法只有try catch, 这两种⽅法只是交给上⼀级⽅法处理.就如⼀个组织⾥ , 有1个⼤佬, 1个党主, 1个⼩弟.⼤佬叫党主⼲活, 堂主叫⼩弟⼲活, 然后⼩弟碰上⿇烦了, 但是⼩弟不会处理这个⿇烦, 只能中断⼯作抛给党主处理, 然后堂主发现这个⿇烦只有⼤佬能处理, 然后抛给⼤佬处理..道理是相通的..5.1 throw 的语法与作⽤throws的语法很简单.语法:throw new XException();其中xException必须是Exception的派⽣类.这⾥注意throw 出的是1个异常对象, 所以new不能省略作⽤就是⼿动令程序抛出1个异常对象.5.2 throw 1个 RuntimeException及其派⽣类我们看回上⾯3.2 的例⼦:[java]1. public int f(int a, int b){2. if (0 == b){3. throw new ArithmeticException("Shit !!! / by zero!");4.5. }6.7. return a/b;8. }5.2.1 throw会中断当前函数, 当前函数执⾏失败(不完整)当这个函数的if 判断了b=0时, 就利⽤throws⼿动抛出了1个异常. 这个异常会中断这个函数. 也就是说f()执⾏不完整, 是没有返回值的.5.2.2, 接下来哪个调⽤这个函数就会在调⽤这个函数的语句上收到异常.[java]1. public void g(){2. int i;3. h();4. i = f(); //recevie excepton5. k();6. }例如上没的g()函数, 在调⽤f() 会收到1个异常.这时g()函数有三种选择.1. 不做任何处理这时, g()收到f()⾥抛出的异常就会打断g()执⾏, 也就是说g()⾥⾯的k(); 被放弃了, 然后程序会继续把这个函数抛给调⽤g()函数.然后⼀级⼀级寻求处理, 如果都不处理, 则抛给jvm处理. jvm会中断程序, 输出异常信息. 这个上没提到过了.2. 使⽤try catch处理如果catch成功, 则g()函数能完整执⾏, ⽽且这个异常不会继续向上抛.如果catch失败(尽量避免), 则跟情况1相同.5.3 throw 1个⾮RuntimeException派⽣类的异常将上⾯的例⼦改⼀下:[java]1. public int f(int a, int b){2. if (0 == b){3. throw new IOException("Shit !!! / by zero!");4. }5.6. return a/b;7. }例如, 我不想抛出ArithmeticException, 我想抛出IOExcetpion.注意这⾥, IOException虽然逻辑上是错误的(完全不是IO的问题嘛), 但是在程序中完全可⾏, 因为程序猿可以根据需要控制程序指定抛出任何1个异常.但是这段代码编译失败, 因为IOException 不是 RuntimeException的派⽣类.java规定:5.3.1 如果⼀个⽅法⾥利⽤throw⼿动抛出1个⾮RuntimeException异常, 必须在函数定义声明⾥加上throws 后缀改成这样就正确了:[java]1. public int f(int a, int b) throws IOException{2. if (0 == b){3. throw new IOException("Shit !!! / by zero!");4. }5.6. return a/b;7. }注意在⽅法定义⾥加上了throws⼦句. 告诉调⽤它的函数我可能抛出这个异常.5.3.2 调⽤该⽅法的⽅法则必须处理这个异常例如抄回上⾯的例⼦, g()调⽤f()函数.[java]1. public void g(){2. int i;3. h();4. i = f(); //recevie excepton5. k()6. }但是编译失败.因为f()利⽤throws 声明了会抛出1个⾮runtimeExcetpion. 这时g()必须做出处理.处理⽅法有两种:1. try catch⾃⼰处理:[java]1. public void g(){2. int i = 0;3. h();4. try{5. i = f(); //recevie excepton6. }7. catch(IOException e){8.9. }10. k();11. }需要注意的是, catch⾥⾯要么写上throws对应的异常(这⾥是 IOException), 要么写上这个异常的超类, 否则还是编译失败.2.g()利⽤throws 往上⼀级⽅法抛.[java]1. public void g() throws IOException{2. int i = 0;3. h();4. i = f(); //recevie excepton5. k();6. }这是调⽤g()的函数也要考虑上⾯的这两种处理⽅法了...但是最终上级的⽅法(main ⽅法)还是不处理的话, 就编译失败, 上⾯说过了, ⾮runtimeException⽆法抛给jvm处理.虽然这两种处理⽅法都能通过编译, 但是运⾏效果是完全不同的.第⼀种, g()能完整执⾏.第⼆种, g()被中断, 也就是g()⾥⾯的k(); 执⾏失败.5.4 throws 的语法.throws稍微⽐throw难理解点:语法是:public void f() throws Exception1, Exception2...{}也就是讲, thorws可以加上多个异常, 注意这⾥抛出的不是对象, 不能加上new.⽽且不是告诉别⼈这个函数有可能抛出这么多个异常. ⽽是告诉别⼈, 有可能抛出这些异常的其中⼀种.5.5 throws 的作⽤.如果为f()函数加上throws后续, 则告诉调⽤f()的⽅法, f()函数有可能抛出这些异常的⼀种.如果f()throws 了1个或若⼲个⾮RuntimeException, 则调⽤f()的函数必须处理这些⾮RuntimeException, 如上⾯的g()函数⼀样.如果f() throws的都是RuntimeException, 则调⽤f()的函数可以不处理, 也能通过编译, 但是实际上还是强烈建议处理它们.实际上, 如果1个⽅法f() throws A,B那么它有可能不抛出任何异常.(程序运⾏状态良好)也有能抛出C异常(应该避免, 最好在throws上加上C)5.6 什么时候应该⽤throws5.6.1 ⼀个函数体⾥⾯⼿动throw了1个RumtimeException, 则这个函数的定义必须加上throws⼦句这个是强制, 告诉别⼈这个函数内有炸弹.5.6.2 ⼀个函数内有可能由系统抛出异常.这个是⾮强制的, 但是如果你知道⼀个函数内的代码有可能抛出异常, 最好还是写上throws 后缀⽆论这个异常是否runtimeExcepion.5.7 ⼀般情况下,调⽤1个带有throws⽅法时怎么办个⼈建议, 如果你调⽤1个函数throws A, B, C那么你就在当前函数写上catch(A)catch(B)catch(C)catch(Exception)这样能处理能保证你的函数能完整执⾏, 不会被收到的异常中断.当然如果你允许你的函数可以被中断, 那么就可以在当前函数定义加上throws A, B 继续抛给上⼀级的函数.5.8 重写⽅法时, throws的范围不能⼤于超类的对应⽅法.例如你在⼀个派⽣类重写⼀个⽅法f(), 在超类⾥的f() throws A, B 你重写⽅法时就不throws出 A,,B,C 或者throws A和B的超类.原因也是由于多态的存在.因为1个超类的引⽤可以指向1个派⽣类的对象并调⽤不同的⽅法. 如果派⽣类throws的范围加⼤那么利⽤多态写的代码的try catch就不再适⽤.六, throw和throws⼀些主要区别.⾯试问得多,单独拉出来写了:6.1 throw 写在函数体内, throws写在函数定义语句中.应付⾯试官.6.2 throw 是抛出1个异常对象, throws是有能抛出异常的种类所以throw后⾯的⼀般加上new 和exception名字().⽽throws后⾯不能加上new的6.3 ⼀个⽅法最多只能throw1个异常, 但是可以throws多个种类异常因为⼀旦⼀个函数throw出1个异常, 这个函数就会被中断执⾏, 后⾯的代码被放弃, 如果你尝试在函数内写两个throw, 编译失败.⽽throws 是告诉别⼈这个函数有可能抛出这⼏种异常的⼀种. 但是最多只会抛出⼀种.6.4 如果在⼀个函数体内throw 1个⾮runtimeException, 那么必须在函数定义上加上throws后缀. 但反过来就不是必须的.原因上⾯讲过了.七, ⾃定义异常.我们可以⾃定义异常, 只需要编写1个类, 继承1个异常类就ok例⼦:[java]1. package Exception_kng;2.3. class User_Exception1 extends ArithmeticException{4. public User_Exception1(String Exception_name){5. super(Exception_name);6. }7.8. public void printStackTrace(){ //overwrite9. super.printStackTrace();10. System.out.printf("hey man, i am an user_defined excetpion\n");11. }12. }13.14. class Exp6{15. public int f(int a, int b){16. if (0 == b){17. throw new User_Exception1("Shit !!! / by zero!"); //use User_defined exception18. }19.20. return a/b;21. }22. }23.24. public class Expt_6{25. public static void g() {26. Exp6 ex = new Exp6();27. int i = 22;28. try{29. i = ex.f(8,0); //throw excetpion30. }catch(User_Exception1 e){31. e.printStackTrace();32. }33. System.out.printf("i is %d\n", i);34. System.out.printf("g() is done!!\n");35. }36. }上⾯的类User_Exception1 就是1个⾃定义异常, 并重写了printStackTrace()⽅法.⼋,java异常的优缺点.8.1 c语⾔是如何处理程序错误的.我们要理解异常的优缺点, ⾸先看看没有异常的是如何处理错误的.下⾯是个例⼦:[cpp]1. //openfile2. if (fileOpen() > 0){3. //check the length of the file4. if (gotLengthOfTheFile() > 0){5. //check the memory6. if (gotEnoughMemory() > 0){7. //load file to memory8. if (loadFileToMem() > 0){9. readFile();10. }else{11. errorCode = -5;12. }13.14. }else{15. errorCode = -5;16. }17.18. }else{19. errorCode = -5;20. }21.22. }else{23. errorCode = -5;24. }25.26. //handle error27. case errorCode....28.29. //release Source30. releaseSource();可以见到处理错误有这些特点1. ⼤部分精⼒都在错误处理.2. 需要把各种可能出现的错误全部考虑到, 才能保证程序的稳定性.3. 程序可读性差, 错误处理代码混杂在其他代码中.4. 出错返回信息少, ⼀旦出错难以调试.5. ⼀旦出现了未考虑到的错误, 资源释放代码⽆法执⾏.8.2 java异常机制下是如何编写上述代码的.[java]1. try{2. fileOpen();3. gotLengthOfTheFile();4. gotEnoughMemory();5. loadFileToMem();6. readFile();7. }8. catch(fileOpenFail) { handle1()}9. catch(gotLengthOfTheFileFail) { handle2()}10. catch(gotEnoughMemoryFail) { handle3()}11. catch(loadFileToMemFail) { handle4()}12. catch(readFileFail) { handle4()}13. catch(Exception e) { handle5()} //catch unexpected error14. finally{15. releasSource();16. }8.3 java异常机制的优点:由上⾯的代码可以看出部分优点:1. 业务代码和错误处理代码分离.2. 强制程序猿考虑程序的稳定性.3. 有利于代码调试(异常信息)4. 即使任何异常产⽣, 能保证占⽤的释放(finally)8.4 java异常机制的缺点:1. 异常嵌套难免影响代码可读性2. 并不能令程序逻辑更加清晰.3. 异常并不能解决所有问题。
exception的用法异常(Exception)是在程序运行过程中发生的错误或异常情况。
在编程中使用异常处理机制可以使程序具备更好的容错性和可靠性。
本文将围绕异常的用法展开,包括异常的定义、异常的分类、异常处理的基本语法以及异常处理的最佳实践等方面进行一步一步的回答。
一、异常的定义异常是指在程序运行过程中发生的错误或异常情况。
它可能是由于程序逻辑的错误、外部环境的变化或用户输入的不合法等原因引起的。
例如,当除数为零时,产生一个除以零的异常。
二、异常的分类在Java中,异常被分为两类:检查异常(Checked Exception)和非检查异常(Unchecked Exception)。
检查异常是指在编译时就需要处理的异常,必须显式地进行捕获或声明抛出。
非检查异常则是在运行时才会被检测到的异常,可以选择是否进行处理。
1. 检查异常检查异常是Exception类及其子类的实例。
它们通常是预料到的、需要处理的异常情况。
如果不处理这些异常,程序将无法通过编译。
2. 非检查异常非检查异常是RuntimeException类及其子类的实例。
它们通常是由程序代码的错误引起的,如空指针异常(NullPointerException)或数组下标越界异常(ArrayIndexOutOfBoundsException)。
这类异常在编译时不需要进行强制处理,但在运行时会导致程序异常终止。
三、异常处理的基本语法异常处理是通过使用try-catch语句块来实现的。
基本语法如下:try {可能会引发异常的代码块} catch (ExceptionType1 e1) {处理ExceptionType1类型的异常} catch (ExceptionType2 e2) {处理ExceptionType2类型的异常} finally {可选的finally块,无论是否发生异常都会被执行}在try块中,我们编写可能会引发异常的代码。
如果发生异常,程序将跳转到对应的catch块,并进行相应的异常处理。
Java中的Exception
1异常相关概述
1.1 什么是异常
➢异常就是Java程序在运行过程中出现的错误。
➢前面接触过的空指针,数组越界,类型转换错误异常等
1.2 Throwable
➢Throwable 类是Java 语言中所有错误或异常的超类。
➢只有当对象是此类(或其子类之一)的实例时,才能通过JVM 或者throw 语句抛出。
1.3异常的继承体系
1.3 JVM默认是如何处理异常的?
➢jvm有一个默认的异常处理机制,就将该异常的名称、异常的信息、异常出现的位置打印在了控制台上,同时程序停止运行。
1.4 Java处理异常的两种方式
➢Java虚拟机处理
➢自己处理
1.5 为什么会有异常
因为你不知道未来会怎么样,需要做个准备(写代码也是,你需要对一些未知的东西做下处理),比如你去旅游,不知道会下雨还是出大太阳,你需要准备雨伞和帽子.如果下雨,我有雨伞可用,如果出大太阳,可以用帽子,也有可能天气刚刚好,雨伞和帽子都用不着,这叫白带。
1.6 回顾几个常见异常
2 try-catch
自己处理异常的两种方试
➢try…catch…finally
➢throws
2.1 try-catch异常处理方式
2.2 try-catch-catch 多个catch处理方式
2.3 try-catch-catch 多个异常-另一种写法
2.4 多个异常处理的一个注意事项
➢catch中父类的Exception只能放在最后面
➢catch一个原则,先由子类处理异常,子类不能处理异常,再由父类处理try {
//1.有可能出现数组越界异常
int[] arr = {1,2,3};
System.out.println(arr[1]);
//2.算术异常
int a = 10 / 2;
//3.空指针异常
int[] arr1 = null;
//NullPointerException np;
System.out.println(arr1[0]);
}catch (ArrayIndexOutOfBoundsException e) {
System.out.println("数组越界异常");
} catch (ArithmeticException e) {
System.out.println("算术异常");
} catch (Exception e) {
System.out.println("其它异常");
}
2.5 "编译时异常"和"运行时异常
➢Java中的异常被分为两大类:"编译时异常"和"运行时异常"。
➢编译时异常和运行时异常的区别
>所有的RuntimeException类及其子类被称为运行时异常
>其他的异常就是编译时异常
编译时异常
运行时异常
➢无需显示处理,也可以像编译时异常一样处理
2.6 Throwable有几个常用的方法
➢Exception是一个继承Throwable的子类
➢getMessage():获取异常信息,返回字符串。
➢toString():获取异常类名和异常信息,返回字符串。
3 throws
3.1 throws方式处理异常
➢实现方式:
1.定义方法时,在方法名后面添加throws 异常类名,相当于问题暴露出来让调用者去处理
main方法
3.2 throws和throw的区别throws
用在方法声明后面,跟的是异常类名
可以跟多个异常类名,用逗号隔开
它表示抛出异常,由该方法的调用者来处理throw
用在方法体内,跟的是异常对象名
只能抛出一个异常对象名,表示抛出异常
4 finally
4.1 try-catch-finally
finally的特点
➢finally的语句体一般情况下一定会执行
➢特殊情况:在执行到finally之前jvm退出了(比如System.exit(0))
finally的作用
4.2 面试题
final,finally和finalize的区别
➢final可以修饰类,不能被继承;修饰方法,不能被重写;修饰变量,只能赋值一次
➢finally是try语句中的一个语句体,不能单独使用,用来释放资源
➢finalize是一个方法,当垃圾回收器确定不存在对该对象的更多引用时,由对象的垃圾回收器调用此方法。
【当对象从内存中消失会调用这个方法】
catch中关于return的面试题
如果catch里面有return语句,请问finally的代码还会执行吗?如果会,请问是在return前
还是return后?
答:会执行,finally的代码在return之前执行
5 自定义异常
5.1案例:自定义年龄异常
AgeException.class
Person.class
5.2自定义异常注意事项
3.如果子类方法内有异常发生,那么子类只能try,不能throws*/
5.3工作中如何使用异常处理
1.原则:如果自己能处理的问题,就用try-catch, 如果自己不能解决的问题,就throws
2.try-catch和throws的区别:
后续程序需要继续运行就用try
后续程序不需要继续运行就throws
3.如果JDK没有提供对应的异常,需要自定义异常。
5.4 案例:自定义一个登录异常
➢注意事项:什么时候方法后面不需要写throws?
方法内throw的异常对象如果是一个运行时异常,方法后面就不会写throws
5.5 案例:自定义一个非法字符异常。