c++-unit10异常处理市公开课一等奖省赛课微课金奖课件.pptx
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- unit10 异常 处理 公开 一等奖 省赛课微课 金奖 课件
- 资源描述:
-
单击此处编辑母版标题样式,单击此处编辑母版文本样式,第二级,第三级,第四级,第五级,*,单击此处编辑母版标题样式,单击此处编辑母版文本样式,第二级,第三级,第四级,第五级,*,第十章 异常处理,大型和十分复杂程序往往会产生一些极难查找甚至是无法防止运行时错误。,当发生运行时错误时,不能简单地结束程序运行,而是退回到任务起点,指犯错误,并由用户决定下一步工作,。,面向对象异常处理(,exception handling,)机制是,C+,语言用以处理这个问题有力工具。,函数执行时,放在,try,(测试)程序块,中任何类型数据对象发生异常,都可被,throw,表示式,抛出,随即,逆调用链退回,,直到被,catch,子句,捕捉,并在此执行,异常处理,,汇报出现异常等情况。从抛出到捕捉,应将各嵌套调用函数残余在栈中自动对象、自动变量和现场保护内容等进行去除。假如已退到入口函数还未捕捉则由,terminate(),函数来终止入口函数。,1/40,第十章 异常处理,10.1,异常概念,10.3,栈展开与 异常,捕捉,10.2,异常处理机制,10.5,异常和继承,10.7 C+,标准库异常类,层次结构,(选读),10.6,异常规范(选读),10.4,异常重新抛出,和,catch_all,子句,2/40,10.1,异常概念,异常概念引入:,异常(,exception,)是程序可能检测到,,运行时不正常情况,,如存放空间耗尽、数组越,界、被,0,除等等。能够预见可能发生在什么地方,不过无法确知怎样发生和何时发生。尤其在一个大型程序(软件)中,程序各部分是由不一样小组编写,它们由公共接口连起来,错误可能就发生在相互配合上,也可能发生在事先根本想不到个别条件组合上。,C+,提供了一些内置语言特征来产生(,raise,)或抛出(,throw,)异常,用以通知“异常已经发生”,然后由预先安排程序段来捕捉(,catch,)异常,并对它进行处理。这种机制能够在,C+,程序两个无关(往往是独立开发)部分进行“异常”通信。由程序某一部分引发了另一部分异常,这一异常可回到引发异常部分去处理(逆着程序函数调用链)。,3/40,10.2,异常处理机制,测到栈满或空就抛出一个异常。,template,void,Stack:Push(,const,T&data),if,(IsFull(),throw,pushOnFull(data);,/,注意加了括号,是结构一个无名对象,elements+top=data;,template,T Stack:Pop(),if,(IsEmpty(),throw,popOnEmpty();,return,elementstop-;,注意,pushOnFull,是,类,,,C+,要求抛出必须是对象,,所以必须有“,(),”,,即,调用结构函数建立一个对象,。,异常与异常抛出:,以栈为例,异常类申明以下,:,class,popOnEmpty.;,/,栈空异常,class,pushOnFull.;,/,栈满异常,4/40,10.2,异常处理机制,throw,表示式,抛出异常,为异常处理,第一步,。,在堆栈压栈和出栈操作中发生错误而抛出异常,理所当然地应由调用堆栈程序来处理。,异常并非总是类对象,,throw,表示式也能够抛出任何类型对象,如枚举、整数等等。但最惯用是类对象。,在,C+,中异常抛出与异常处理之间有一整套程序设计机制。首先采取关键字,try,,组成一个,try,块(,try block,),,它包含了,抛出异常,语句。当然也能够是包含了这么调用语句,该语句所调用函数中有能够抛出异常语句。,异常处理机制:,5/40,10.2,异常处理机制,int,main(),int,a9=1,2,3,4,5,6,7,8,9,b9=0,i;,stackistack(8);,try,fo,r(i=0;i9;i+)istack.,Push,(ai);,istack.PrintStack();,catch,(,pushOnFull,)cerr”,栈满”,endl;,try,for,(i=0;i9;i+)bi=istack.,Pop,();,catch,(,popOnEmpty,)cerr”,栈空”,endl;,for,(i=0;i9;i+)coutbit;,coutendl;,return,0;,try,块与,catch,子句关系实例:,6/40,10.2,异常处理机制,由,catch,字句捕捉并处理异常是,第二步,。注意与,catch,语句分别,匹配,是在压栈和出栈组员函数模板中,throw,语句,一个抛出,pushOnFull,类无名对象,另一个抛出,popOnEmpty,类无名对象。,在编制程序时有一条,通例,:把正常执行程序与异常处理两部分分隔开来,这么使代码更易于跟随和维护。在上例中,我们能够把两个,try,块合成一个,而把两个,catch,子句都放在函数最终。,说明:,这里有两个,try,块,分别对应压栈与出栈;也有两个,catch,子句(,catch clause,),分别处理压栈时栈满和出栈时栈空。,7/40,10.2,异常处理机制,1,假如没有异常发生,继续执行,try,块中代码,与,try,块相关联,catch,子句被忽略,程序正常执行,,main(),返回,0,。,2,当第一个,try,块在,for,循环中抛出异常,则该,for,循环退出,,try,块也退出,去执行可处理,pushOnFull,异常,catch,子句。,istack.PrintStack(),不再执行,被忽略。,3,假如第二个,try,块调用,Pop(),抛出异常,则退出,for,和,try,块,去执行可处理,popOnEmpty,异常,catch,子句。,4,当某条语句抛出异常时,跟在该语句后面语句将被跳过。程序执行权交给处理异常,catch,子句,假如没有,catch,子句能够处理异常,则交给,C+,标准库中定义,terminate(),。,流程控制规则:,8/40,10.3,栈展开与异常捕捉,catch,子句由三部分组成:关键字,catch,、圆括号中,异常申明,以及复合语句中,一组语句,。,catch,子句不是函数,所以圆括号中不是形参,而是一个异常类型申明,能够是类型也能够是对象。,catch,子句使用:它只有一个子句,没有定义和调用之分。使用时由系统按规则自动在,catch,子句列表中匹配。,catch,子句能够包含返回语句(,return,),也可不包含返回语句。,包含返回语句,则整个程序结束,。而不包含返回语句,则执行,catch,列表之后下一条语句。,catch,子句,说明:,当,try,块中语句抛出异常时,系统经过查看跟在其后,catch,子句列表,来查找可处理该异常,catch,子句。,9/40,10.3,栈展开与异常捕捉,对应在,throw,表示式中,结构抛出对象也要有实参:,throw,pushOnFull(data);,/data,即,Push(,const,&data),中参数,data,template,class,pushOnFull,T _value;,public,:,pushOnFull(T i):_value(i),/,或写为,pushOnFull(T i)_value=i;,T value(),return,_value,;,新私有数据组员,_value,保留那些不能被压入栈中值。该值即调用结构函数时实参。,catch,子句异常申明探讨:,异常申明中能够是一个对象申明。以栈为例。当栈满时,要求在异常对象中,保留不能被压入到栈中值,,,pushOnFull,类可定义以下:,10/40,10.3,栈展开与异常捕捉,在,catch,子句中,要取得,_value,,须调用,pushOnFull,中组员函数,value(),:,catch,(,pushOnFull eObj,),cerr,”,栈满”,eObj.value(),”,未压入栈”,endl;,return,1;,在,catch,子句异常申明中申明了对象,eObj,,用它来调用,pushOnFull,类对象组员函数,value(),。异常对象是在抛出点被创建,与,catch,子句是否显式要求创建一个异常对象无关,该对象总是存在,在,catch,子句中只是为了调用异常处理对象组员函数才申明为对象,不用类。,*catch,子句异常申明中采取对象只是一个形式。甚至异常并非一个类对象时,也能够用一样格式,比如异常为一枚举量,这时就等效于按值传递,而不是调用类对象公有组员。,11/40,10.3,栈展开与异常捕捉,catch,子句异常申明与函数参数申明类似,能够是按值传送,也能够是按引用传递。对大型类对象降低无须要复制是很有意义,所以对于类类型异常,其异常申明最好也是被申明为引用。如:,catch,(pushOnFull&eObj),cerr”,栈满”,eObj.value()”,未压栈”,endl;,return,1;,使用引用类型异常申明,,catch,子句能够修改异常对象,但仅仅是异常对象本身,正常程序部分量并不会被修改。与普通类对象不一样,实际上异常对象处理完后,生命期也就结束了。,只有需要重新抛出异常(在下一节中讨论),修改操作才有意义。,【,例,10.1】,包含栈满或空异常完整程序。,12/40,10.3,栈展开与异常捕捉,把程序正常处理代码和异常处理代码分离最清楚方法是定义函数,try,块(,Function try Block,)。这种方法是把整个函数包含在,try,块中。,一个函数,try,块把一组,catch,子句同一个函数体相关联。假如函数体中语句抛出一个异常,则考虑跟在函数体后面处理代码来处理该异常。函数,try,块对结构函数尤其有用。,【,例,10.1_1】,定义函数,try,块(,Function try Block,)。,函数,try,块使用:,13/40,寻找匹配,catch,子句有固定过程:假如,throw,表示式位于,try,块中,则检验与,try,块相关联,catch,子句列表,看是否有一个子句能够处理该异常,有匹配,则该异常被处理;找不到匹配,catch,子句,则在主调函数中继续查找。假如一个函数调用在退出时带有一个被抛出异常未能处理,而且这个调用位于一个,try,块中,则检验与该,try,块相关联,catch,子句列表,看是否有一个子句匹配,有,则处理该异常;没有,则查找过程在该函数主调函数中继续进行。即这个查找过程逆着嵌套函数调用链向上继续,直到找处处理该异常,catch,子句。,只要碰到第一个匹配,catch,子句,就会进入该,catch,子句,进行处理,查找过程结束。,14/40,10.3,栈展开与异常捕捉,在栈异常处理例子中,对,popOnEmpty,,首先应在,istack,组员函数,Pop(),中找,因为,Pop(),中没有,try,块,不存在,catch,子句,所以,Pop(),带着一个异常退出。下一步是检验调用,Pop(),函数,这里是,main(),,在,main(),中对,Pop(),调用位于一个,try,块中,则可用与该,try,块关联,catch,子句列表中某一个来处理,找到第一个,popOnEmpty,类型异常申明,catch,子句,并进入该子句进行异常处理。,栈展开:,因发生异常而逐步退出复合语句和函数定义过程,被称为,栈展开,(stack unwinding),。这是异常处理关键技术。,异常对程序影响通常不但是在发生异常那个局部范围中,而且可能逆调用链而上,甚至整个任务。所以,异常处理应该在其对程序影响终止处进行,甚至是在调用该任务菜单处进行。,15/40,10.3,栈展开与异常捕捉,在栈展开期间,在退出域中有某个局部量是类对象,栈展开过程将自动调用该对象析构函数,完成资源释放。所以,C+,异常处理过程本质上反应是“,资源获取是由结构函数实现,而资源释放是由析构函数完成,”。采取面向对象程序设计,取得资源动作封装在类结构函数中,释放资源动作封装在类析构函数中,当一个函数带着未处理异常退出时,函数中这种类对象被自动销毁,资源(包含动态空间分配资源和打开文件)释放。所以,由文件重构对象应该放在结构函数中,把对象存入文件应该放在析构函数中,。,栈展开时资源释放,:,异常处理应该用于面向对象程序设计。对非面向对象程序设计假如函数动态取得过资源,因异常,这些资源释放语句可能被忽略,则这些资源将永远不会被自动释放。,16/40,10.3,栈展开与异常捕捉,异常不能够保持在未被处理状态。异常表示一个程序不能够继续正常执行,这是非常严重问题,假如没有找处处理代码,程序就调用,C+,标准库中定义函数,terminate(),。,异常对象探讨:,异常对象是在,throw,表示式中建立并抛出:,throw,表示式经过调用异常类结构函数创建一个暂时对象,然后把这个暂时对象复制到一个被称为异常对象(,exception object,)存贮区中,它确保会连续到异常被处理完。,17/40,10.3,栈展开与异常捕捉,函数调用和异常处理区分:,建立,函数调用,所需要全部信息在,编译,时已经取得,而,异常处理,机制要求,运行时,支持。对于普通函数调用,经过函数重载解析过程,编译器知道在调用点上哪个函数会真正被调用。但对于,异常处理,编译器不知道特定,throw,表示式,catch,子句在哪个函数中,以及在处理异常之后执行权被转移到哪儿。这些都在运行时刻决定,异常是随机发生,异常处理,catch,子句是逆调用链进行查找,,这与运行时多态,虚函数也是不一样。当一个异常不存在处理代码时,系统无法通知用户,所以要有,terminate(),函数,它是一个运行机制,当没有处理代码(,catch,子句)能够匹配,被抛出异常时由它通知用户。,18/40,10.4,异常重新抛出和,catch_all,子句(选读),rethrow,表示式仍为:,throw;,但仅有一个关键字,因为,异常类型在,catch,语句,中已经有了,无须再指明。被重新抛出异常就是原来异常对象。,不过重新抛出异常,catch,子句应该把自己做过工作告诉下一个处理异常,catch,子句,往往要对异常对象做一定修改,以表示一些信息,所以,catch,子句中异常申明必须被申明为引用,,这么修改才能真正做在异常对象本身中,而不是副本中。,异常重新抛出与连续处理:,当,catch,语句捕捉一个异常后,可能不能完全处理异常,完成一些操作后,该异常必须由函数链中更上级函数来处理,这时,catch,子句能够重新抛出(,rethrow,)该异常,把异常传递给函数调用链中更上级另一个,catch,子句,由它进行深入处理。,19/40,10.4,异常重新抛出和,catch_all,子句(选读),通用,catch,子句,(catch_all),:,catch(.),代码*,/,任何异常都能够进入这个,catch,子句。这里三个点称为省略号。花括号中复合语句用来执行指定操作。,异常发生后按栈展开(,stack unwinding,)退出,动态分配,非类对象,资源不会自动释放,通常在,catch_all,子句中释放。,void,fun1(),int,*res;,res=,new,int100;,/,定义一个资源对象,try,/,代码包含使用资源,res,和一些可能引发异常抛出操作,/,异常可能有各种,catch,(.),/,不论是那种异常都在此释放,delete,res;,/,释放资源对象,res,throw,;,/,重新抛出异常,delete,res;,/,正常退出前释放资源对象,res;,20/40,10.4,异常重新抛出和,catch_all,子句(选读),catch_all,子句能够单独使用,也能够与其它,catch,子句联合使用。假如联合使用,它必须放在,相关,catch,子句表最终,。,catch,子句被检验次序与它们在,try,块之后排列次序相同,一旦找到了一个匹配,则后续,catch,子句将不再检验,按此规则,,catch_all,子句(,catch(.),)处理表前面所列各种异常之外异常。,假如只用,catch_all,子句进行某项操作,则其它操作应由,catch,子句,重新抛出异常,,逆调用链去查找新处理子句来处理,,不能在子句列表中再安排一个处理同一异常子句,因为第二个子句是永远执行不到,。,通用,catch,子句应用:,21/40,10.5,异常和继承,定义一个称为,Excp,基类,由它来打印错误信息:,class,Excp public:void print(string msg)cerrmsgendl;,再从该基类派生出两个异常类,:,class,stackExcp:,public,Excp.;,/,栈异常类基类,class,mathExcp:,public,Excp.;,/,数学库异常基类,深入派生出其它,异常类,:,class,popOnEmpty:,public,stackExcp.;,/,栈空退栈异常,class,pushOnFull:,public,stackExcp.;,/,栈满压栈异常,class,zeroOp:,public,mathExcp.;,/,数学库零操作异常,class,divideByZero:,public,mathExcp.;,/,数学库被零除异常,异常层次结构:,在,C+,程序中,表示异常类通常被组成为一个组(即如在前面各节讨论那样)或者一个,层次结构,。,形成了三层结构。,22/40,10.5,异常和继承,在层次结构下,异常抛出会有一些不一样,以下做法是错,:,if,(full(),pushOnFull except(data);,stackExcp*pse=,/pse,指向类对象为,pushOnFull,throw,*pse;,/,抛出异常对象类型为,stackExcp,这里被创建异常类对象是,stackExcp,类类型,尽管,pse,指向一个实际类型为,pushOnFull,对象,但那是一个暂时对象,复制到异常对象存放区中时创建却是,stackExcp,类异常对象。所以该异常不能被,pushOnFull,类型,catch,子句处理。,层次结构异常抛出:,23/40,10.5,异常和继承,在处理类类型异常时,,catch,子句排列次序是非常主要。,catch,(pushOnFull).,/,处理,pushOnFull,异常,catch,(stackExcp).,/,处理栈其它异常,catch,(Excp).,/,处理普通异常,派生类类型,catch,子句必须先出现,以确保只有在没有其它,catch,子句适用时,才会进入基类类型,catch,子句。,异常,catch,子句无须是与异常最匹配,catch,子句,而是,最先匹配到,catch,子句,,就是第一个碰到能够处理该异常,catch,子句。所以在,catch,子句列表中最特化(匹配条件最严格),catch,子句必须先出现。,catch,子句排列次序:,24/40,10.5,异常和继承,类层次结构异常一样能够重新抛出(,rethrow,),把一个异常传递给函数调用列表中,更上层,另一个,catch,子句:,throw;,类层次结构下异常重新抛出:,重新抛出异常仍是原来异常对象。假如程序中抛出了,pushOnFull,类类型异常,而它,被基类,catch,子句处理,,并在其中,再次被抛出,,那么这个异常,仍是,pushOnFull,类异常,,而不是其基类异常。,25/40,10.5,异常和继承,在基类,catch,子句处理是异常对象基类子对象一份副本,该副本只在该,catch,子句中被访问,重新抛出是原来异常对象。这个放在异常对象存放区中异常生命期应该是在处理该异常一系列子句中最终一个退出时才结束,也就是直到这时,才由异常类析构函数来销毁它。这一系列子句是由重新抛出联络起来。,【,例,10.2】,异常层次结构中虚函数。,为了调用派生类对象虚拟函数,异常申明必须为一个,指针或引用。,虚函数是类层次结构中多态性基本伎俩,异常类层次结构中也能够定义虚拟函数。,26/40,10.6,异常规范,一个函数异常规范违例只能在运行时才能被检测出来。假如在运行时,函数抛出了一个没有被列在它异常规范中异常时(而且函数中所抛出异常,,没有在该函数内部处理,)则系统调用,C+,标准库中定义函数,unexpected(),。,仅当函数中所抛出异常,没有在该函数内部处理,而是逆调用链回溯寻找匹配,catch,子句时候,异常规范才起作用。,假如异常规范为,throw(),,则表示不得抛出任何异常。,异常规范(,exception specification,)提供了一个方案,能够伴随函数申明列出该函数可能抛出异常,并确保该函数不会抛出任何其它类型异常,在,stack,类定义中可有:,void,Push(const T&data),throw,(pushOnFull);,T Pop(),throw,(popOnEmpty);,组员函数类内申明和类外定义必须,必须在两处都有相同异常规范,,,一样异常规范。,异常规范引入:,27/40,10.6,异常规范,class,CBase,public,:,virtual int,fun1(,int,),throw,();,virtual int,fun2(,int,),throw,(,int,);,virtual,string fun3(),throw,(,int,string);,class,CDerived:,public,CBase,public,:,int,fun1(,int,),throw,(,int,);,/,错!异常规范不如,throw(),严格,int,fun2(,int,),throw,(,int,);,/,对!有相同异常规范,string fun3(),throw,(string);,/,对!异常规范比,throw(int,string),更严格,虚函数中异常规范:,派生类虚拟函数异常规范必须与基类虚函数异常一样或更严格。因为当派生类虚函数被指向基类类型指针调用时,,确保不会违反基类组员函数异常规范,。,28/40,10.7 C+,标准库异常类层次结构,(,选读,),exception,类接口以下:,namespace,std,/,注意在名字空间域,std,中,class exception,public:,exception(),throw(),;,/,默认结构函数,exception(,const,exception&),throw(),;,/,复制结构函数,exception&,operator,=(,const,exception&),throw(),;,/,复制赋值操作符,virtual,exception(),throw(),;,/,析构函数,virtual,const,char*,what(),const,throw(),;,/,返回一个,C,格调字符串,,目标是为抛出异常提供文本描述,;,C+,标准库中异常层次根类被称为,exception,,定义在库头文件,中,29/40,10.7 C+,标准库异常类层次结构,(,选读,),C+,标准库提供逻辑异常:,invalid_argument,异常,接收到一个无效实参,抛出该异常。,out_of_range,异常,收到一个不在预期范围中实参,则抛出。,length_error,异常,汇报企图产生“长度值超出最大允许值”对象,domain_error,异常,用以汇报域错误(,domain error,)。,C+,标准库提供运行时异常:,range_error,异常,汇报内部计算中范围错误。,overflow_error,异常,汇报算术溢犯错误。,underflow_error,异常,汇报算术下溢错误。,以上三个异常是由,runtime_error,类派生。,bad_alloc,异常。当,new(),操作符不能分配所要求存放区时,会抛出该异常。它是由基类,exception,派生。,【,例,10.3】,为类模板,Array,重新定义下标操作符,,假如索引值越界,它会抛出一个,out_of_range,类型异常。,30/40,第十章 异常处理,完,谢谢!,31/40,例,10.1,堆栈异常处理,template,class,pushOnFull,/,栈满异常申明,T _value;,public,:,pushOnFull(T i)_value=i;,T value(),return,_value;,void,print()cerr,栈满,,value(),未压入栈,endl;,;,template,class,popOnEmpty,/,栈空异常申明,public,:,void,print()cerr,栈已空,无法出栈,endl;,;,32/40,例,10.1,堆栈异常处理,template,class,Stack,int,top;,/,栈顶指针(下标),T*elements;,/,动态建立数值,int,maxSize;,/,栈最大允纳元素个数,public,:,Stack(int=20);,/,栈如不指定大小,设为,20,元素,Stack(),delete,elements;,void,Push(,const,T&data),throw,(pushOnFull);,/,压栈,T Pop(),throw,(popOnEmpty);,/,弹出,,top-,T GetElem(,int,i),return,elementsi;,/,返回指定元素,void,MakeEmpty()top=-1;,/,清空栈,bool,IsEmpty(),const,return,top=-1;,/,判栈空,bool,IsFull()const,return,top=maxSize-1;,/,判栈满,void,PrintStack();,/,输出栈内全部数据,;,33/40,例,10.1,堆栈异常处理,template,void,Stack:Push(,const,T&data),if,(IsFull(),throw,pushOnFull(data);,/,栈满则抛出异常,elements+top=data;,/,栈顶指针先加,1,,元素再进栈,,top,是指向栈顶元素,template,T Stack:Pop(),if,(IsEmpty(),throw,popOnEmpty();,/,栈已空则不能退栈,抛出异常,return,elementstop-;,/,返回栈顶元素,同时栈顶指针退,1,34/40,例,10.1,堆栈异常处理,int,main(),int,a9=1,2,3,4,5,6,7,8,9,b9=0,i;,Stackistack(8);,try,for,(i=0;i9;i+)istack.Push(ai);,/,到,a8,时栈满,异常,istack.PrintStack();,catch,(pushOnFull,try,for,(i=0;i9;i+)bi=istack.Pop();,catch,(popOnEmpty,for,(i=0;i9;i+)coutbit;,coutendl;,return,0;,35/40,例,10.1_1,函数,try,块(,Function try Block,),int,main(),try,int,a9=1,2,3,4,5,6,7,8,9,b9=0,i;,Stack istack(8);,for,(i=0;i9;i+)istack.Push(ai);/,到,a8,时栈满,异常,istack.PrintStack();,for,(i=0;i9;i+)bi=istack.Pop();,for,(i=0;i9;i+)coutbit;/,发生异常后不会执行,coutendl;,return,0;,catc,h(pushOnFull&eObj),eObj.print();return 1;,catch,(popOnEmpty&eObj),eObj.print();return 2;,36/40,例,10.2,异常层次结构中虚函数,class,Excp,public,:,virtual void,print()cerr,发生异常,endl;,class,stackExcp:,public,Excp,public,:,virtual void,print()cerr,栈发生异常,endl;,class,pushOnFull:,public,stackExcp,public,:,virtual void,print()cerr,栈满,不能压栈,endl;,class,popOnEmpty:,public,stackExcp,public,:,void,print()cerr,栈已空,无法出栈,endl;,37/40,例,10.2,异常层次结构中虚函数,int,main(),int,a9=1,2,3,4,5,6,7,8,9,b9=0,i;,Stack istack(8);,try,for,(i=0;i9;i+)istack.Push(ai);,/,到,a8,时栈满,异常,istack.PrintStack();,catch,(Excp,/,调用虚函数,pushOnFull:print(),try,for(i=0;i9;i+)bi=istack.Pop();,catch,(Excp,/,调用虚函数,popOnEmpty:print(),for,(i=0;i9;i+)coutbit;,coutendl;,return,0;,catch,子句输出为:,栈满,不能压栈,栈已空,无法出栈,38/40,例,10.3 Array,重新定义下标操作符,template,class,Array,int,size;elemType*ia;,public,:,explicit,Array(,int,sz=DefaultArraySize),size=sz;ia=new elemType size;,Array(),delete,ia;,elemType&,operator,(,int,ix),const,/,下标运算符,重载,if,(ix=size),/,增加异常抛出,预防索引值越界,string eObj=out_of_range error in Array:,operator,();,throw,out_of_range(eObj);,return,iaix;,/,保留原来,全部索引方式,private:,int,size;elemType*ia;,;,39/40,例,10.3 Array,重新定义下标操作符,int,main(),int,i;,Array arr;,try,for,(i=0;i=DefaultArraySize;i+),arri=i+1;,/,写入,ia10,时出界,coutsetw(5)arri;,coutendl;,catch,(,const,out_of_range&excp),cerrnexcp.what()n;,/,打印,out_of_range error in Array:operator(),return,-1;,return,0;,40/40,展开阅读全文
咨信网温馨提示:1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。




c++-unit10异常处理市公开课一等奖省赛课微课金奖课件.pptx



实名认证













自信AI助手
















微信客服
客服QQ
发送邮件
意见反馈



链接地址:https://www.zixin.com.cn/doc/12595394.html