第6章异常处理与资源管理.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第6章异常处理与资源管理

* 第6章 异常处理与资源管理 重点 1.清除栈 2.异常退出 3.类的二阶构造 6.1 清除栈 指出以下代码存在的风险: Symbian通过3种方式来提高程序的容错性和增加程序的稳定性—清除栈机制、异常退出机制和类的二阶构造机制 void main() { CClass* pc = new CClass; pc-use(); … delete pc; return; } 风险1:use函数调用过程中可能产生异常,导致程序退出 风险2:构造函数调用过程中可能产生异常,导致程序退出 Symbian提供的清除栈机制能够减少程序异常带来的内存泄漏:Symbian程序在启动后会创建一个清除栈,在程序中新创建了对象后,立刻把对象的指针压到清除栈中,程序正常执行后,把前面压入清除栈中的指针弹出,由程序自己释放内存,如果在程序执行过程中产生了异常退出,导致后面的内存释放代码不能执行,那么Symbian的异常处理框架就会把异常捕获到,负责弹出指针并释放内存。 参考以下代码,理解Symbian C++的清除栈机制: 1 清除栈机制 void CreateObjectL() { CMyObject* obj1 = new (ELeave)CMyObject; //给obj1分配内存 CleanupStack::PushL(obj1); //将obj1压入清除栈 CMyObject* obj2 = new(ELeave)CMyObject; //给obj2分配内存 CleanupStack::PushL(obj2); //将obj2压入清除栈 obj1-UseL(); //调用CMyObject类的成员函数UseL(),该函数可能产生异常 obj2-UseL(); //调用CMyObject类的成员函数UseL(),该函数可能产生异常 CleanupStack::Pop(); //出栈 CleanupStack::Pop(); //出栈 delete obj1; //清除内存空间 delete obj2; //清除内存空间 } void main() { TRAPD(err,CreateObjectL()); //调用CreatObjectL,并通过TRAPD来捕获异常 if(err != KErrNode) {//有异常,处理异常} } 最常使用的CleanupStack类的方法如下: class CleanupStack { IMPORT_C static void PushL(TAny* aPtr); IMPORT_C static void PushL(CBase* aPtr); IMPORT_C static void PushL(TCleanupItem anItem); IMPORT_C static void Pop(); IMPORT_C static void Pop(TInt aCount); IMPORT_C static void PopAndDestroy(); IMPORT_C static void PopAndDestroy(TInt aCount); 。。。 } 在Symbian中,不论是控制台应用程序,还是GUI应用程序,都自动创建了一个清除栈,程序只需要直接使用就可以了,使用的基本步骤如下: 创建对象 把对象指针压栈 使用对象提供的有可能异常退出的函数,也就是函数名后缀有“L”的 出栈 根据情况决定是否释放对象 2 使用清除栈 CMyObject* obj = new (ELeave)CMyObject; //创建对象 CleanupStack::PushL(obj); //将obj对象压入清除栈 obj-UseL(); //调用CMyObject类的成员函数UseL(),该函数可能产生异常 CleanupStack::Pop(); //出栈 delete obj; //清除内存空间 用法一 3 清除栈的特殊用法 CMyObject* obj = new (ELeave)CMyObject; //创建对象 CleanupStack::PushL(obj); //将obj对象压入清除栈 obj-UseL(); //调用CMyObject类的成员函数UseL(),该函数可能产生异常 CleanupStack::PopAndDestroy(); //出栈并清除内存 用法二 templateclass T void CleanupClosePushL(T aRef); //适合资源类对象的释放 templateclass T void CleanupReleasePushL(T aRef); //适合需要调用Release函数释放

文档评论(0)

yan698698 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档