- 1、本文档共29页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
06 章 异常处理、递归和单体程序设计方法 知识点 本章总体纲要 异常处理 递归方法 单体(Singleton)程序设计模式 Java 异常处理(Exception)基础 异常(Exception)? 异常(Exception)是正常程序流程所不能处理或没有处理的异常情况或异常事件。 在有些书中,异常也称作例外。 格式 在try语句块中包含可能会产生异常的语句 紧接着若干个catch语句块,进行异常处理 catch语句块与finally语句块至少存在一个 为什么需要异常? 强制程序异常/错误处理 同时指定需要异常的种类 异常处理模型提供了一种统一处理异常/错误的模式 传统程序方法: 设置标志位,或返回错误码,分别处理各种异常情况。但在编程时常常出现这样的情况:忘了对某些异常情况进行处理,尤其是当存在多个分支或者多个开发人员共同开发程序时。 简化对异常情况的处理,减少if-else语句 什么时候会发生异常? 数组的下标越界 打开不存在的文件 网络无法连接 操作数超出所要求的范围 少了所需加载的类, 自定义异常,要求程序处理 处理异常的几种常用方法 一旦捕获异常,马上进行处理 重新抛出异常 捕获异常,但并不处理 通过语句System.exit()退出应用程序 异常(Exceptions)类型 常见异常 内存耗尽 数组下标越界 除数为0 非法的参数(方法的参数) 异常(Exception)的层次结构 运行时发生的异常(RuntimeExceptions) 异常随时都可以发生 ArrayIndexOutOfBoundsException NullPointerException 定义了引用,但不指向任何对象(object) ClassCastException 数据类型间的转换不合法 良好的编程习惯,可以减少很多异常的发生 受检异常和非受检异常 受检异常 必须在方法声明时通过throws列出 在编译时就能被检测出 非受检测异常 不必在throws列表中 错误(Errors) 和运行时异常(RuntimeExceptions) 受检异常,必须处理才能通过编译 运行时异常只有在运行时才能被发现 错误常常指的是致命性错误,常常也无法处理 处理多种异常(Exception)类型 如果含有多外catch语句块,则异常会被第一个与其相匹配的catch语句块处理 finally 语句块 在异常处理过程中,finally 语句块总是会被执行到: 无论有没有异常发生,也无论有没有异常被捕捉到 可选项: finally 语句块,通常位于catch 语句块的后面 可以用来释放try语句块中获得的资源 例如,关闭在try语句块中打开的文件 throws 列表 在方法的声明处列出所有的受检异常 返回类型 方法名( 参数列表 ) throws 异常类型1, 异常类型2,… { // 方法体 } 在本方法内就可以不处理这些异常 调用该方法的方法就必须处理这些异常 示例: public static void g( ) throws Exception { throw new Exception( ); } // 方法g结束 异常处理: 捕捉-或者-声明 如果一个方法调用一个抛出受检异常的方法(含有throws列表的方法),则该方法必须捕捉这些受检异常,或通过throws列表声明这些异常 重新抛出异常 如果catch语句块不处理某种异常,可以重新抛出异常 抛出异常的方法: throw e; 由其外层的try- catch 语句块处理 本章总体纲要 异常处理 递归方法 单体(Singleton)程序设计模式 递归 如果在方法定义中直接或间接地调用该方法本身,就称为递归 汉诺塔(Tower of Hanoi)问题 有三根柱子:S、T和E 柱子S上套着n个盘,小盘依次在大盘上面 现在要求: 每次只能将一根柱子最上面的一个盘移动到另一根柱子上 不允许将大盘放在小盘上面 只能利用这三根柱子 将在柱子S上的n个盘移动到柱子E上 示例 // J_Hanoi.java; 开发者: 雍俊海 // 利用递归求解汉诺塔(Tower of Hanoi)问题的例程。 public class J_Hanoi { public static void mb_hanoi(int n, char start, char temp, char end) { if (n=1) System.out.println(将盘从 + start + 移到 + end); else { mb_hanoi(n-1, start, end, temp);
您可能关注的文档
- 办公软件种类.doc
- 初中学习及小学学习的不同.doc
- 用Visual C++显示位图的原理及方法.docx
- 第7章异常处理及程序调试技术.doc
- 浅析贝多芬钢琴奏鸣曲《悲怆》曲式及结构.doc
- 怎样发展邮政速递物流业务.doc
- 人类生命工程学本体的快乐及审美文档.doc
- 3D视频技术原理和应用.doc
- 网页消重与净化.docx
- 常用模板种类和工程应用特点.docx
- 工厂供电与安全用电课件.pptx
- 2024-2030年工业罐混合器和搅拌器行业市场现状供需分析及投资评估规划分析研究报告.docx
- 常用的铸造合金课件.pptx
- 2024-2030年工业液体涂料行业市场现状供需分析及重点企业投资评估规划分析研究报告.docx
- 幼儿教师沟通能力的提升课件.pptx
- 2024-2030年工业燃油产业政府战略管理与区域发展战略研究报告.docx
- 2024-2030年工业机械釉纸行业市场现状供需分析及重点企业投资评估规划分析研究报告.docx
- 常见肿瘤标志物的临床应用护理课件.pptx
- 已更改背景专业技术人员的职业道德课件.pptx
- 希腊神话的谱系与影响课件.pptx
文档评论(0)