C++程序设计教程15.pptVIP

  1. 1、本文档共25页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C++程序设计教程(第二版) 第十五章 异常 Chapter 15 Exception 异常是一种程序控制机制,与函数机制独立和互补   函数是一种以栈结构展开的上下函数衔接的程序控制系统,异常是另一种控制结构,它依附于栈结构,却可以同时设置多个异常类型作为网捕条件,从而以类型匹配在栈机制中跳跃回馈. 异常设计目的: 栈机制是一种高度节律性控制机制,面向对象编程却要求对象之间有方向、有目的的控制传动,从一开始,异常就是冲着改变程序控制结构,以适应面向对象程序更有效地工作这个主题,而不是仅为了进行错误处理。 异常设计出来之后,却发现在错误处理方面获得了最大的好处 第十五章内容 1. 错误处理的复杂性 ( Error Proccessing Complexity ) 传统的错误处理方式: 1 遇到错误,终止运行,低级粗暴 2 遇到错误,循调用返回给上层函数一个错误信息,忽略了模块体系 3 遇到错误,改变全局错误变量的值,并函数返回,破坏了程序结构 4 遇到错误,调用事先设计好的下层错误处理函数,可惜错误往往不是自己所能解决的了的! 异常处理的语法: 1 框定异常发生的可能范围 2 定义异常处理 3 抛掷异常 int main(int argc, char** argv){ ifstream in(argv[1]); try{ if(!in) throw string(argv[1]); }catch(string s){ couts+File Opening Error.\n; return 1; } for(string s; getline(in, s); ) couts“\n”; } 异常擅长于在函数调用链中腾挪 void f0(){ throw string(“请处理\n”); } void f1(){ f0(); } void f2(){ f1(); } void f3(){ f2(); } void f4(){ f3(); } void f5(){ f4(); } int main(){ try{ f5(); } catch(string){ cout“处理中\n”; } } 系统中提供了标准异常 在标准模块中若发生标准错误,会自动抛掷标准异常,无须程序员指定throw地点 int* f(){ return new int[1000000000]; } int main(){ int* sp; try{ sp=f(); }catch(bad_alloc){ coutBad Allocation...\n; return 1; } //using sp; } 异常可以函数为依托,层层布网: 下层捕捉失败后,抛掷会继续上传,触动上层捕捉.直至系统最后一道防线,例如,下列代码将输出“int exception.”: void f(){ try{ throw 12; }catch(char){ cout“char exception.\n”; } } int main(){ try{ f(); }catch(int){ coutint exception.\n; } } 没有申述的函数,默认为任何抛掷都可穿透该函数 class A; class B; void f1()throw(A,B); void f2(); void f3()throw(); 对于函数g中的调用,可能捕捉到函数f1的A和函数f2的B异常抛掷,但捕捉不到函数f3中的任何抛掷. 注:同一个函数,其声明与定义中的申述应一致 捉不住处理: 抛掷而无布网捕捉的异常将直逼系统的最后一道防线 void f(){ if(...) throw A; } void g(){ try{ f(); }catch(B){ cout“exception B\n”; } } int main(){ g(); } throw A将穿透函数f,g和main,抵达系统的最后一道防线——激发terminate函数.该函数调用引起运行终止的abort函数. 最后一道防线的函数可以由程序员设置.从而规定其终止前的行为. 抛掷子类可被基类捕捉 try{ if(...) throw OtherErr; }catch(MyException me){ if(string(me.what())==HardwareErr){...} // 停机 if(string(me.what())==PerformErr){...}

文档评论(0)

专业好文档 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:6110200002000000

1亿VIP精品文档

相关文档