智能指针.docVIP

  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文档。上传文档
查看更多
智能指针

C++智能指针应用分析 [ 录入者:NCRE100 |?时间:2009-02-14 18:13:25 | 作者: | 来源:NCRE100.com | 浏览:58次 ] 一:关于纠错,MFC和ATL中智能指针的应用   1:在Windows中如何方便的查看当前进程使用的内存。   虽然代码简单,但对纠错时有大用处,不用不停的通过切换任务管理器来查看内存使用。代码如下: UINT?C_BaseUtil::getProcessMemoryUsed() {  UINT?uiTotal?=?0L;  HANDLE?hProcess?=?::GetCurrentProcess();  PROCESS_MEMORY_COUNTERS?pmc;  if(::GetProcessMemoryInfo(hProcess,pmc,sizeof(pmc)))   uiTotal?=?pmc.WorkingSetSize;  return?uiTotal; }   注意:由于内存使用会是一个不稳定的过程,所以,需要在程序稳定时进行调用,才能准确。   2:在使用Com的Dispatch指针时,如果不使用COM智能指针,容易出现的错误。   2.1:忘记在所有出口释放指针。   ?   如: IXMLDOMDocument?*pDoc?=?NULL; CoCreateInstance(...) …… pDoc-Release();   错误:如果中间代码发生异常,则pDoc未能正常释放,造成内存泄露。   2.2:重复使用同一指针变量,导致中间生成的Dispatch指针未能释放。 IXMLDOMNode?*pNode?=?NULL; if(FAILED(pDoc-selectSingleNode(_bstr_t(Workbook),?pNode))?||?pNode==NULL) throw(_T(selectSingleNode?failed!)); if(FAILED(pDoc-selectSingleNode(_bstr_t(Workbook),?pNode))?||?pNode==NULL) throw(_T(selectSingleNode?failed!));   错误:pNode未释放就开始第二次调用,造成内存泄露。或者类似pNode?=?pNode2的这种写法,也随手就出问题了。必须调用if(pNode)?{pNode-Release();pNode=NULL;}   3:使用MFC提供的Com智能指针解决上述问题。   注意:可通过查看源码,看到#import生成的智能指针的原型是_com_ptr_t。   3.1: IXMLDOMDocumentPtr?docPtr?=?NULL; docPtr.CreateInstance(...) ……   这下不会有问题了,因为docPtr在析构时会有正确的释放处理。   3.2: IXMLDOMNodePtr?nodePtr?=?NULL; if(FAILED(pDoc-selectSingleNode(_bstr_t(Workbook),?nodePtr))?||?nodePtr==NULL) throw(_T(selectSingleNode?failed!)); if(FAILED(pDoc-selectSingleNode(_bstr_t(Workbook),?nodePtr))?||?nodePtr==NULL) throw(_T(selectSingleNode?failed!));   不会出错了,因为_com_ptr_t重载了操作符,在取指针时,有如下操作,嘿。 Interface**?operator()?throw() {  _Release();  m_pInterface?=?NULL;  return?m_pInterface; }   3.3:?nodePtr?=?nodePrt2?,也不会有问题:   仔细查看源码,在=操作符中会调用Attach,而Attach的做法是:会先调用_Release();   3.4:再看看值传递:拷贝构造函数如下 template?_com_ptr_t(const?_com_ptr_t?cp)?throw() :?m_pInterface(cp.m_pInterface) {?  _AddRef();? }   嗯,也不会有问题。 C++智能指针应用分析 [ 录入者:NCRE100 |?时间:2009-02-14 18:13:25 | 作者: | 来源:NCRE

文档评论(0)

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

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

1亿VIP精品文档

相关文档