实验四 异常处理和包装类的编程练习.doc_第1页
实验四 异常处理和包装类的编程练习.doc_第2页
实验四 异常处理和包装类的编程练习.doc_第3页
实验四 异常处理和包装类的编程练习.doc_第4页
实验四 异常处理和包装类的编程练习.doc_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

实验四 异常处理和包装类的编程练习实验目的 了解异常类的作用,掌握对异常的捕获和处理方式,了解包装类的作用和特点以及基本数据类型与包装类的对应关系,掌握包装类的使用方法。实验要求1、 理解系统异常处理的机制;2、 创建自定义的异常类型;3、 了解基本数据类型和包装类的对应关系;4、 理解基本数据类型与包装类之间的区别和联系;5、 掌握基本数据类型与包装类之间相互转换的方法。实验内容1、 使用trycatch语句处理异常1.1、 异常类型匹配的处理方式(1) 程序功能:在程序中主动产生一个ArithmeticException 类型被0 除的异常, 并用catch 语句捕获这个异常。最后通过ArithmeticException 类的对象e 的方法getMessage 给出异常的具体类型并显示出来。(2) 程序源代码如下。 public class EXP5_1 public static void main(String arg3) System.out.println(这是一个异常处理的例子n); try int i=10; i /=0; catch (ArithmeticException e) System.out.println(异常是:+e.getMessage(); finally System.out.println(finally 语句被执行); (3) 编译并运行,结果如图5.1所示。图 5.11.2、 异常类型不匹配的处理方式(1) 程序源代码如下。 public class EXP5_2 public static void main(String args) System.out.println(“这是一个异常处理的例子n”); try int i=10; i /=0; catch (IndexOutOfBoundsException e) System.out.println(异常是:+e.getMessage(); finally System.out.println(finally 语句被执行); (2) 编译并运行,结果如图5.2所示。图 5.2 因为EXP5_2 程序试图捕获一个异常类为IndexOutOfBoundsException 的异常,但发生的异常却是ArithmeticException 类,所以,程序可以通过编译但在运行时,系统会给出异常报告:报告所发生的但没有被捕获的异常。不过在此之前,其它语句和finally 语句将会被执行。1.3、 包含多个catch子句的异常处理方式(1) 程序功能:在try 子句中设计两个可能出现的异常,当a 为0 时会发生异常。另外一个是肯定的异常,因为数组c 的长度为1,定义c42是为法的。通过两个catch 子句分别来捕获异常。(2) 程序源代码如下。 public class EXP5_3 public static void main(String args) try int a=args.length; System.out.println(na = +a); int b=42/a; int c=1; c42=99; catch (ArithmeticException e) System.out.println(发生了被 0 除:+e); catch (ArrayIndexOutOfBoundsException e) System.out.println(数组下标越界:+e); (3) 编译并运行,结果如图5.3所示。图 5.32、 使用throw语句抛出异常 在上面的实验中,可以发现,异常对象是Java 运行时由系统抛出的。抛出异常也可以通过使用throw 语句实现。throw 是Java 语言的关键字,用来告知编译器此处要发生一个异常。throw 后面要跟一个新创建的异常类对象,用于指出异常的名称和类型。(1) 程序源代码如下。 public class EXP5_4 static void throwProcess() try throw new NullPointerException(空指针异常); catch (NullPointerException e) System.out.println(n在throwProcess方法中捕获+e.getMessage(); throw e; public static void main(String args) try throwProcess(); catch (NullPointerException e) System.out.println(再次捕获:+e); (2) 编译并运行,结果如图5.4所示。图 5.43、 使用throws语句 throws 子句一般用来表明在使用该方法时可能抛出异常但不捕获的异常。异常由系统来处理。throws 子句也可以指出抛出异常是RuntimeException 或自定义异常类,即异常的类型,以便准备调用其它方法捕获它,这种情况一般需要两个方法来分别处理抛出异常和处理异常。(1) 程序功能:在这个程序中的mathod 方法中使用throws 子句抛出异常,在main 方法中捕获处理异常。(2) 程序源代码如下。 import java.io.*; public class EXP5_5 static void mathod() throws IllegalAccessException System.out.println(n 在 mathod 中抛出一个异常); throw new IllegalAccessException(); public static void main(String args) try mathod(); catch (IllegalAccessException e) System.out.println(在 main 中捕获异常:+e); (3) 编译并运行,结果如图5.5所示。图 5.54、 使用finally子句 当一个异常被抛出时,程序的执行流程就不再是连续的了,会跳过某些语句,甚至会由于没有与之匹配的catch 子句而过早地返回,结束程序的运行。为了确保一段代码不管发生什么异常都能被执行,可以使用finally 子句。每个try 语句至少都要有一个与之相配的catch 或finally 子句。 从一个方法中返回到调用它的另外一个方法,可以通过return 语句或通过一个没有被捕获的异常,但finally 子句总是在返回前被执行。(1) 程序功能:在类EXP5_6 的mathodA 方法中使用try 子句捕获异常,使用finally 子句处理异常。(2) 程序源代码如下。 class EXP5_6 static void mathodA() try System.out.println(nmathodA 抛出一个异常); throw new RuntimeException(); finally System.out.println(执行 mathodA 的 finally); static void mathodB() try System.out.println(mathodB 正常返回); return; finally System.out.println(执行 mathodB 的 finally); public static void main(String args) try mathodA(); catch (Exception e) mathodB(); (3) 编译并运行,结果如图5.6所示。图5.65、 创建自定义的异常类(1) 程序功能:通过继承Exception 异常类创建一个自定义异常类MyException,然后再创建一个主类EXP5_7 使用自定义异常类MyException。(2) 程序源代码如下。 class MyException extends Exception private int x; MyException(int a) x=a; public String toString() return 自定义异常类MyException; public class EXP5_7 static void mathod(int a) throws MyException System.out.println(t 此处引用 mathod (+a+); if (a10) throw new MyException(a); / 主动抛出MyException System.out.println(正常返回); public static void main(String args) try System.out.println(n 进入监控区,执行可能发生异常的程序段); mathod(8); mathod(20); mathod(6); cat

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论