欢迎来到天天文库
浏览记录
ID:59448073
大小:241.50 KB
页数:40页
时间:2020-09-18
《C++程序设计 第10章 异常处理ppt课件.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、第十章异常处理大型和十分复杂的程序往往会产生一些很难查找的甚至是无法避免的运行时错误。当发生运行时错误时,不能简单地结束程序运行,而是退回到任务的起点,指出错误,并由用户决定下一步工作。面向对象的异常处理(exceptionhandling)机制是C++语言用以解决这个问题的有力工具。函数执行时,放在try(测试)程序块中的任何类型的数据对象发生异常,都可被throw表达式抛出,随即逆调用链退回,直到被catch子句捕获,并在此执行异常处理,报告出现的异常等情况。从抛出到捕获,应将各嵌套调用函数残存在栈中的自动对象
2、、自动变量和现场保护内容等进行清除。如果已退到入口函数还未捕获则由terminate()函数来终结入口函数。第十章异常处理10.1异常的概念10.3栈展开与异常捕获10.2异常处理的机制10.5异常和继承10.7C++标准库异常类层次结构(选读)10.6异常规范(选读)10.4异常的重新抛出和catch_all子句10.1异常的概念异常概念的引入:异常(exception)是程序可能检测到的,运行时不正常的情况,如存储空间耗尽、数组越界、被0除等等。可以预见可能发生在什么地方,但是无法确知怎样发生和何时发生。特别在
3、一个大型的程序(软件)中,程序各部分是由不同的小组编写的,它们由公共接口连起来,错误可能就发生在相互的配合上,也可能发生在事先根本想不到的个别的条件组合上。C++提供了一些内置的语言特性来产生(raise)或抛出(throw)异常,用以通知“异常已经发生”,然后由预先安排的程序段来捕获(catch)异常,并对它进行处理。这种机制可以在C++程序的两个无关(往往是独立开发)的部分进行“异常”通信。由程序某一部分引发了另一部分的异常,这一异常可回到引起异常的部分去处理(逆着程序的函数调用链)。10.2异常处理的机制测到
4、栈满或空就抛出一个异常。templatevoidStack::Push(constT&data){if(IsFull())throwpushOnFull(data);//注意加了括号,是构造一个无名对象elements[++top]=data;}templateTStack::Pop(){if(IsEmpty())throwpopOnEmpty();returnelements[top--];}注意pushOnFull是类,C++要求抛出的必须是对
5、象,所以必须有“()”,即调用构造函数建立一个对象。异常与异常抛出:以栈为例,异常类声明如下:templateclasspopOnEmpty{...};//栈空异常templateclasspushOnFull{...};//栈满异常10.2异常处理的机制throw表达式抛出异常为异常处理的第一步。在堆栈的压栈和出栈操作中发生错误而抛出的异常,理所当然地应由调用堆栈的程序来处理。异常并非总是类对象,throw表达式也可以抛出任何类型的对象,如枚举、整数等等。但最常用的是类
6、对象。在C++中异常抛出与异常处理之间有一整套程序设计的机制。首先采用关键字try,构成一个try块(tryblock),它包含了抛出异常的语句。当然也可以是包含了这样的调用语句,该语句所调用的函数中有能够抛出异常的语句。异常处理机制:10.2异常处理的机制intmain(){inta[9]={1,2,3,4,5,6,7,8,9},b[9]={0},i;stackistack(8);try{for(i=0;i<9;i++)istack.Push(a[i]);istack.PrintStack();}cat
7、ch(pushOnFull){cerr<<”栈满”<){cerr<<”栈空”<8、一个抛出pushOnFull类的无名对象,另一个抛出popOnEmpty类的无名对象。在编制程序时有一条惯例:把正常执行的程序与异常处理两部分分隔开来,这样使代码更易于跟随和维护。在上例中,我们可以把两个try块合成一个,而把两个catch子句都放在函数最后。说明:这里有两个try块,分别对应压栈与出栈;也有两个catch子句(catchclause),分别
8、一个抛出pushOnFull类的无名对象,另一个抛出popOnEmpty类的无名对象。在编制程序时有一条惯例:把正常执行的程序与异常处理两部分分隔开来,这样使代码更易于跟随和维护。在上例中,我们可以把两个try块合成一个,而把两个catch子句都放在函数最后。说明:这里有两个try块,分别对应压栈与出栈;也有两个catch子句(catchclause),分别
此文档下载收益归作者所有