- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
                        查看更多
                        
                    
                未及时加入列表,异常抛出时内存泄漏 【问题描述】CPArray类为管理对象指针的列表,具有自动释放功能。 程序正常情况下,加入CPArray中的对象可以得到释放,在有异常发生的时候,对象的不到释放,造成内存泄漏。 【问题定位】分析下面的代码段,发现new的pObj已经放到了自动释放列表中,粗看代码没什么问题; ... CPArray myArray(AUTO_FREE); CMyObject *pObj = NULL; for(int i = 0; i  N; i++) {     pObj = new CMyObject;     pObj-m_ID = i; ...     Function1(pObj);     ...     myArray.Add(pObj); } ... 跟踪Function1函数,在该函数内有异常抛出,导致myArray.Add(pObj)语句没有被执行,造成pObj对象没有被释放。 未及时加入列表,异常抛出时内存泄漏(续) 【纠正措施】对象创建以后,首先加入到自动释放列表中,再执行其他操作; 以上代码修改为: ... CPArray myArray(AUTO_FREE); CMyObject *pObj = NULL; for(int i = 0; i  N; i++) {     pObj = new CMyObject;     myArray.Add(pObj);     pObj-m_ID = i; ...     Function1(pObj);     ... } ...     无论函数Function1()是否有异常,都能保证对象得到释放。 【举一反三】使用自动释放列表的程序,要第一时间将新创建对象加入到列表中;调用函数时,要考虑到函数是否会抛出异常。 没有释放队列中的内存 【问题描述】发现加载**软件命令出现内存泄漏现象。 【问题定位】分析下面的代码段,发现删除队列节点时,没有删除节点对应的内存 。。。。。。。。。。。。。。 //获得加载命令附加信息指针 CDldAllSwAddInfo *pDldAllSwInfo = (CDldAllSwAddInfo *)(g_TaskId.GetDataPtr(iTaskId));  //清除已经完成加载的单板信息 pDldAllSwInfo-m_pBoardReportList.RemoveAt(0); pDldAllSwInfo-m_pBoardReportList.SetSize(iSize-1); pDldAllSwInfo-m_pBoardReportList.FreeExtra();  没有释放队列中的内存(续) 【纠正措施】添加如下代码,问题解决: if(pDldAllSwInfo-m_pBoardReportList[0] != NULL) {     delete pDldAllSwInfo-m_pBoardReportList[0];     pDldAllSwInfo-m_pBoardReportList[0] = NULL; } pDldAllSwInfo-m_pBoardReportList.RemoveAt(0); pDldAllSwInfo-m_pBoardReportList.SetSize(iSize-1); pDldAllSwInfo-m_pBoardReportList.FreeExtra(); 【举一反三】处理链表或队列时,如果删除了其中的一个节点,还必须同时释放节点申请的内存  重复连接数据库 【问题描述】B020版本中,对****模块进行系统测试。某个VOD处于上载中,点击Refresh,刷新其状态,则页面运行非常慢,最终出现错误提示页面。 【问题定位】在****方法的synchronizeCAStatus(ArrayList)方法中,在循环体内new Operater(),即在循环体中创建数据库连接 try {    for (int index = 0; index  vodCAList.size(); index++)    {         dbOper = new DBOperator();         。。。。。。。。。。。。。。     } } catch (Exception e) {         。。。。。。。。。。。。。。 } finally {       dbOper.close(); }  重复连接数据库(续) 【纠正措施】数据库连接不能放在循环体中创建,否则会导致内存泄漏,数据库连接异常。将dbOper = new DBOperator();语句提前到循环体外,try语句内 try {       dbOper = new DBOperator();  
                您可能关注的文档
最近下载
- 大班社会《危险游戏我不玩》.pptx VIP
- 2025年山西运城事业单位考试笔试试题(含答案).pdf
- 城市轨道交通运营设备维修与更新技术规范第5部分:通信.pdf VIP
- 医院感染暴发事件应急处理.pptx VIP
- 《食品营养学》 课件 第四章 各类食物的营养特点.pdf
- 基于BIM的建设工程文件归档管理系统.pdf VIP
- 护理学(专升本)模考试题(含参考答案).docx VIP
- 员工离职申请表(模版)(标准版).doc VIP
- 实验五___DPS统计分析操作.pptx VIP
- 《Unit 3 Lesson 3 Letters all around》(说课稿)-2024-2025学年冀教版(三起)(2024)英语三年级上册.docx VIP
 原创力文档
原创力文档 
                        

文档评论(0)