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