使用异常处理程序错误课件.ppt

上传人(卖家):晟晟文业 文档编号:4379042 上传时间:2022-12-04 格式:PPT 页数:33 大小:606KB
下载 相关 举报
使用异常处理程序错误课件.ppt_第1页
第1页 / 共33页
使用异常处理程序错误课件.ppt_第2页
第2页 / 共33页
使用异常处理程序错误课件.ppt_第3页
第3页 / 共33页
使用异常处理程序错误课件.ppt_第4页
第4页 / 共33页
使用异常处理程序错误课件.ppt_第5页
第5页 / 共33页
点击查看更多>>
资源描述

1、使用异常处理程序错误使用异常处理程序错误第十五讲第十五讲2回顾什么是常量?Java中,常量的定义规则有哪些?什么是面向接口编程,它的好处是什么?3预习检查什么是异常?Java中,如何进行异常处理?请说明throw 与 throws的区别与联系?4本章任务升级Hello,完成如下功能:n根据课程代码输出课程名称n输出各学期平均课时等信息n使用log4j记录异常日志5n掌握Java的异常处理机制q运用 try、catch、finally 处理异常q运用 throw 抛出异常q运用 throws 声明异常n掌握log4j的用法,能够记录异常日志本章目标6生活中的异常n正常情况下,小王每日开车去上班,

2、耗时大约30分钟n但是,异常情况迟早要发生!一路畅通一路畅通堵车!堵车!撞车!撞车!7程序中的异常public class Hello public static void main(String args)System.out.print(请输入课程代号请输入课程代号(1至至3之间的数字之间的数字):);Scanner in=new Scanner(System.in);int courseCode=in.nextInt();/从键盘输入整数从键盘输入整数switch(courseCode)case 1:System.out.println(C#编程编程);break;case 2:Syst

3、em.out.println(Java编程编程);break;case 3:System.out.println(SQL基础基础);输入:输入:2输出:输出:Java编程编程输入:输入:B程序中断运行!程序中断运行!正常情况:正常情况:异常情况:异常情况:8什么是异常n异常就是在程序的运行过程中所发生的不正常的事件,它会中断正在运行的程序绕行或者等待绕行或者等待请求交警解决请求交警解决异常!异常!n面对异常该怎么办呢?通常情况下,我们会这样处理:程序运行程序运行程序中断运行程序中断运行堵车!堵车!撞车!撞车!生活中,我们会根据不同的异常进行相应的处理,生活中,我们会根据不同的异常进行相应的处理

4、,而不会就此中断我们的生活而不会就此中断我们的生活9什么是异常处理nJava语言使用异常处理机制为程序提供了错误处理的能力程序中预先想好了程序中预先想好了 对付异常的处理办法对付异常的处理办法 异常!异常!程序运行程序运行处理完毕,程序继续运行处理完毕,程序继续运行对异常进行处理对异常进行处理10Java中如何进行异常处理nJava的异常处理是通过5个关键字来实现的:try、catch、finally、throw、throws 捕获异常捕获异常 catchtryfinally执行可能产生执行可能产生 异常的代码异常的代码 捕获异常捕获异常 无论是否发生异常,无论是否发生异常,代码总能执行代码总

5、能执行手动抛出异常手动抛出异常 抛出异常抛出异常 throw声明异常声明异常 声明方法可能要声明方法可能要抛出的各种异常抛出的各种异常 throws11try/catch块7-1trycatch try/catch 块后的代码段块后的代码段public void method()try /代码段代码段(此处不会产生异常此处不会产生异常)catch(异常类型异常类型 ex)/对异常进行处理的代码段对异常进行处理的代码段/代码段代码段n使用try/catch块捕获异常,分为三种情况:第一种情况第一种情况 12try/catch块7-2n使用示例模拟第一种情况:public class Except

6、ion public static void main(String args)System.out.print(请输入课程代号请输入课程代号(1至至3之间的数字之间的数字):);Scanner in=new Scanner(System.in);try int courseCode=in.nextInt();switch(courseCode)case 1:System.out.println(C#编程编程);break;case 2:System.out.println(Java编程编程);break;case 3:System.out.println(SQL基础基础);catch(Exc

7、eption ex)System.out.println(输入不为数字输入不为数字!);System.out.println(欢迎提出建议欢迎提出建议!);输入:输入:2Java编程编程欢迎提出建议欢迎提出建议!控制台输出控制台输出13try/catch块7-3trycatch异常类型匹配异常类型匹配 try/catch 块后的代码段块后的代码段进入进入catch块块public void method()try /代码段代码段 1 /产生异常的代码段产生异常的代码段 2 /代码段代码段 3 catch(异常类型异常类型 ex)/对异常进行处理的代码段对异常进行处理的代码段4/代码段代码段5n

8、使用try/catch块捕获异常,分为三种情况:第二种情况第二种情况 产生异常对象产生异常对象 程序继续执行程序继续执行异常是一种特殊的对象,异常是一种特殊的对象,类型为类型为java.lang.Exception或其子类或其子类 发生异常发生异常14try/catch块7-4n使用示例模拟第二种情况:public class Exception public static void main(String args)System.out.print(请输入课程代号请输入课程代号(1至至3之间的数字之间的数字):);Scanner in=new Scanner(System.in);try i

9、nt courseCode=in.nextInt();switch(courseCode)case 1:System.out.println(C#编程编程);break;case 2:System.out.println(Java编程编程);break;case 3:System.out.println(SQL基础基础);catch(Exception ex)System.out.println(输入不为数字输入不为数字!);ex.printStackTrace();System.out.println(欢迎提出建议欢迎提出建议!);输入:输入:B输入不为数字输入不为数字!异常堆栈信息异常堆栈

10、信息欢迎提出建议欢迎提出建议!控制台输出控制台输出15nprintStackTrace的堆栈跟踪功能显示出程序运行到当前类的执行流程 public class Exception public static void main(String args)System.out.print(请输入课程代号请输入课程代号(1至至3之间的数字之间的数字):);Scanner in=new Scanner(System.in);try int courseCode=in.nextInt();/此处代码省略此处代码省略 catch(Exception ex)System.out.println(输入不为数字

11、!输入不为数字!);ex.printStackTrace();System.out.println(欢迎提出建议欢迎提出建议!);try/catch块7-5java.util.InputMismatchExceptionat java.util.Scanner.throwFor(Scanner.java:840)at java.util.Scanner.next(Scanner.java:1461)at java.util.Scanner.nextInt(Scanner.java:2091)at java.util.Scanner.nextInt(Scanner.java:2050)at s2

12、jsp.sg.ch05.AccpException.main(AccpException.java:23)异常类型异常类型异常堆栈信息异常堆栈信息在此方法中抛出了异常在此方法中抛出了异常16try/catch块7-6trycatch异常类型不匹配异常类型不匹配 try/catch 块后的代码段块后的代码段程序中断运行程序中断运行 发生异常发生异常public void method()try /代码段代码段 1 /产生异常的代码段产生异常的代码段 2 /代码段代码段 3 catch(异常类型异常类型 ex)/对异常进行处理的代码段对异常进行处理的代码段4/代码段代码段5n使用try/catch

13、块捕获异常,分为三种情况:第三种情况第三种情况 产生异常对象产生异常对象 17try/catch块7-7n使用示例模拟第三种情况:public class Exception2 public static void main(String args)System.out.print(请输入课程代号请输入课程代号(1至至3之间的数字之间的数字):);Scanner in=new Scanner(System.in);try int courseCode=in.nextInt();switch(courseCode)case 1:System.out.println(C#编程编程);break;c

14、ase 2:System.out.println(Java编程编程);break;case 3:System.out.println(SQL基础基础);catch(NullPointerException ex)System.out.println(输入不为数字!输入不为数字!);System.out.println(欢迎提出建议!欢迎提出建议!);输入:输入:B程序中断运行程序中断运行18try/catch/finally 2-1n在try/catch块后加入finally块,可以确保无论是否发生异常,finally块中的代码总能被执行try 块块 finally 块块 catch 块块 无

15、异常无异常 有异常有异常 19try/catch/finally 2-2 public class Exception3 public static void main(String args)System.out.print(请输入课程代号请输入课程代号(1至至3之间的数字之间的数字):);Scanner in=new Scanner(System.in);try int courseCode=in.nextInt();switch(courseCode)case 1:System.out.println(C#编程编程);break;case 2:System.out.println(Jav

16、a编程编程);break;case 3:System.out.println(SQL基础基础);catch(Exception ex)System.out.println(输入不为数字!输入不为数字!);finally System.out.println(欢迎提出建议!欢迎提出建议!);输入:输入:2Java编程编程欢迎提出建议欢迎提出建议!控制台输出控制台输出输入:输入:B输入不为数字输入不为数字!欢迎提出建议欢迎提出建议!第一种情况:第一种情况:无异常无异常第二种情况:第二种情况:有异常有异常 20小结 1n编写一个类ExceptionTest1,在main方法中使用try、catch、

17、finally:q在try块中,编写被0除的代码q在catch块中,捕获被0除所产生的异常,并且打印异常信息q在finally块中,打印一条语句21public void method()try /代码段代码段 /产生异常产生异常(异常类型异常类型2)catch(异常类型异常类型1 ex)/对异常进行处理的代码段对异常进行处理的代码段 catch(异常类型异常类型2 ex)/对异常进行处理的代码段对异常进行处理的代码段 catch(异常类型异常类型3 ex)/对异常进行处理的代码段对异常进行处理的代码段/代码段代码段多重catch块 2-1n一段代码可能会引发多种类型的异常n当引发异常时,会按

18、顺序来查看每个 catch 语句,并执行第一个与异常类型匹配的catch语句n执行其中的一条 catch 语句之后,其后的 catch 语句将被忽略 try 与异常类型与异常类型1不匹配不匹配try/catch 块后的代码段块后的代码段发生异常发生异常产生异常对象产生异常对象catch与异常类型与异常类型2匹配匹配catchcatch程序继续执行程序继续执行进入进入catch块块22多重catch块 2-2public class Exception4 public static void main(String args)Scanner in=new Scanner(System.in);t

19、rySystem.out.print(“请输入请输入S1的总学时:的总学时:);int totalTime=in.nextInt();/总学时总学时System.out.print(“请输入请输入S1的课程数目:的课程数目:);int totalCourse=in.nextInt();/课程数目课程数目System.out.println(“S1各课程的平均学时为:各课程的平均学时为:+totalTime/totalCourse);catch(InputMismatchException e1)System.out.println(输入不为数字输入不为数字!);catch(Arithmetic

20、Exception e2)System.out.println(课程数目不能为零课程数目不能为零!);catch(Exception e)System.out.println(发生错误发生错误:+e.getMessage();输入:输入:270 H 在安排在安排catch语句的顺序时,首先应该捕获最特殊的异常,语句的顺序时,首先应该捕获最特殊的异常,然后再逐渐一般化,即先子类后父类然后再逐渐一般化,即先子类后父类 输出:输出:输入不为数字输入不为数字!进入第一个进入第一个catch块块输入:输入:270 0 输出:输出:课程数目不能为零课程数目不能为零!进入第二个进入第二个catch块块23抛

21、出异常n如果在当前环境无法解决一个异常,就要将其抛出,把异常交给调用者处理 public class Teacher private String id;/教员编号,长度应为教员编号,长度应为7 public void setId(String pId)/判断教员编号的长度是否为判断教员编号的长度是否为7 if(pId.length()=7)id=pId;else throw new IllegalArgumentException(参数长度应为参数长度应为7!);抛出异常:抛出异常:在不使用在不使用try、catch语句或语句或throws的前提下,只可以抛出运行的前提下,只可以抛出运行时异

22、常对象时异常对象RuntimeException或其子类对象,如:或其子类对象,如:NullPointerException、IllegalArgumentException等等public class AccpTeacherTest public static void main(String args)AccpTeacher teacher=new AccpTeacher();try teacher.setId(088);catch(IllegalArgumentException ex)System.out.println(ex.getMessage();捕获异常捕获异常参数长度应为参数

23、长度应为7!控制台输出控制台输出24声明异常public class Teacher private String id;/教员编号教员编号,长度应为长度应为7 public void setId(String pId)throws IllegalArgumentException/判断教员编号的长度是否为判断教员编号的长度是否为7 if(pId.length()=7)id=pId;else throw new IllegalArgumentException(参数长度应为参数长度应为7!);public class TeacherTest public static void main(St

24、ring args)AccpTeacher teacher=new AccpTeacher();try teacher.setId(088);catch(IllegalArgumentException ex)System.out.println(ex.getMessage();由调用者捕获异常由调用者捕获异常 声明该方法可能会产生异常声明该方法可能会产生异常 25小结 2n编写类ExceptionTest2:q定义两个方法:go()和main()q在go方法中声明要抛出异常,在该方法体内,抛出一个Exception对象q在main()方法中,调用go方法,使用try/catch捕获go方法中

25、抛出的异常26 使用log4j记录日志信息public class TeacherTest public static void main(String args)Teacher teacher=new Teacher();try teacher.setId(088);catch(IllegalArgumentException ex)System.out.println(ex.getMessage();控制台输出控制台输出参数长度应为参数长度应为7!如果想把错误信息如果想把错误信息保存到文件中,该保存到文件中,该如何处理?如何处理?使用使用log4j可以解决这个问题,可以解决这个问题,log

26、4j是一个流行的日志记录工具是一个流行的日志记录工具 这是使用这是使用log4j后,存储在文本文件中的日志信息后,存储在文本文件中的日志信息 27什么是日志n日志:用来记录一些重要的操作信息n有价值的日志数据能够帮助用户提前发现和避免灾难,并且找到事件发生的原因 public class TeacherTest public static void main(String args)Teacher teacher=new Teacher();try teacher.setId(088);catch(IllegalArgumentException ex)System.out.println(e

27、x.getMessage();在控制台输出日志信在控制台输出日志信息,提示用户出现错息,提示用户出现错误的原因误的原因 28如何使用log4j记录日志项目项目 属性属性:弹出项目的属性窗口:弹出项目的属性窗口n第一步:在工程中加入log4j所使用的jar文件Java构建路径构建路径库库添加外部添加外部JAR:弹出选择:弹出选择JAR的窗口的窗口通过选择通过选择JAR的窗口,找到的窗口,找到log4j-1.2.x.jar,并确认,并确认回到项目的属性窗口,点击确定回到项目的属性窗口,点击确定1234演示:在工程中加入演示:在工程中加入log4j所使用的所使用的jar文件文件 29如何使用log4

28、j记录日志n第二步:创建log4j.properties文件选择欲使用选择欲使用log4j的项目的项目右键点击右键点击src 新建新建其他其他:弹出选择向导窗口:弹出选择向导窗口在选择向导窗口中,选择常规在选择向导窗口中,选择常规 文件文件 下一步:弹出新建文件的窗口下一步:弹出新建文件的窗口在新建文件窗口中,输入文件名在新建文件窗口中,输入文件名log4j.properties 完成:创建工作结束完成:创建工作结束12330如何使用log4j记录日志n第三步:使用log4j记录日志信息import org.apache.log4j.Logger;public class TeacherLog

29、4j public static void main(String args)Teacher teacher=new Teacher();Logger logger=Logger.getLogger(AccpTeacherLog4j.class.getName();try logger.debug(设置教员的编号。设置教员的编号。);teacher.setId(088);catch(IllegalArgumentException ex)logger.info(ex.getMessage();获取日志记录器,获取日志记录器,这个记录器将负责这个记录器将负责控制日志信息控制日志信息 使用使用Lo

30、gger对象的对象的debug、info方法输方法输出日志信息出日志信息 31如何使用log4j记录日志n第四步:编写log4j.properties文件,配置日志信息#把日志信息输出到控制台把日志信息输出到控制台#log4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.Target=System.outlog4j.appender.stdout.layout=org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionP

31、attern=%dyyyy-MM-dd HH:mm:ss%m%n#把日志信息输出到文件:把日志信息输出到文件:accp.log#log4j.appender.file=org.apache.log4j.FileAppenderlog4j.appender.file.File=accp.loglog4j.appender.file.layout=org.apache.log4j.PatternLayoutlog4j.appender.file.layout.ConversionPattern=%dyyyy-MM-dd HH:mm:ss%l%m%n#设置优先级别、以及输出源设置优先级别、以及输出源

32、#log4j.rootLogger=debug,stdout,file日志信息将写到文件中日志信息将写到文件中 指定日志输出的文件名指定日志输出的文件名 指定输出格式:指定输出格式:显示日期和显示日期和log信息信息 设置优先级别为设置优先级别为debug、日志被输出到多个输出源日志被输出到多个输出源 日志信息将写到控制台日志信息将写到控制台 指定日志信息输出目标指定日志信息输出目标指定输出格式:指定输出格式:显示日期,日志发生位置显示日期,日志发生位置和日志信息和日志信息 输出源名称输出源名称优先级从高到低分别是优先级从高到低分别是ERROR、WARN、INFO、DEBUG 在此处,如果优先

33、级别设为在此处,如果优先级别设为info,那么使用,那么使用debug方法打印的日志信息将不被输出方法打印的日志信息将不被输出 32如何使用log4j记录日志n运行效果展示控制台输出效果控制台输出效果包含日期包含日期与日志信息与日志信息文件输出效果文件输出效果包含日期、日志发生位置、与包含日期、日志发生位置、与日志信息日志信息1233总结请给出下列Java代码的运行结果 public class Test public static void main(String args)new Test().test();public void test()try int arr=new int3;ar

34、r3=2;System.out.println(try);catch(ArrayIndexOutOfBoundsException e)System.out.println(catch 1);catch(Exception e)System.out.println(catch 2);finally System.out.println(finally);n修改log4j.properties文件,设置优先级为info,在控制台以及accp.log文件中将会输出什么内容?控制台输出控制台输出catch 1finally将只输出使用将只输出使用Logger对象的对象的info方法输出的日志信息方法输出的日志信息

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 办公、行业 > 各类PPT课件(模板)
版权提示 | 免责声明

1,本文(使用异常处理程序错误课件.ppt)为本站会员(晟晟文业)主动上传,163文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。
2,用户下载本文档,所消耗的文币(积分)将全额增加到上传者的账号。
3, 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(发送邮件至3464097650@qq.com或直接QQ联系客服),我们立即给予删除!


侵权处理QQ:3464097650--上传资料QQ:3464097650

【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。


163文库-Www.163Wenku.Com |网站地图|