VC++操作EXCEL内存泄露问题
来源:互联网 发布:网络专线 编辑:程序博客网 时间:2024/04/28 21:01
一般VC++操作EXCEL的操作步骤我就不写了,度娘一下一大堆。
好久以前写在博客里面的一篇草稿,现在博客开张了,一并放出来吧。
2014年11月为了EXCEL的“切换到、重试、取消”问题前前后后改了三天吧。除了网上搜出来的添加以下几句话来屏蔽该对话框外。
COleMessageFilter* pMsgFilter= AfxOleGetMessageFilter();
if (pMsgFilter)
{
pMsgFilter->EnableBusyDialog(FALSE);
pMsgFilter->SetBusyReply(SERVERCALL_RETRYLATER);
pMsgFilter->EnableNotRespondingDialog(TRUE);
pMsgFilter->SetMessagePendingDelay(-1);
}
更加本质的问题在于操作EXCEL时内存释放的问题。
以下是本次的经验:
1、 不管是Range、RangeCell、Application、WorkSheet等何种类型的变量,Attach后就要记得Release。
2、 万万不可以如此用法。此用法中GetItem循环20000次内存增长30M。
Range range;
_variant_t var;
range.AttachDispatch(usedRange.GetCells());
var = range.GetItem(_variant_t(ii),_variant_t(jj));
range.ReleaseDispatch();
正确的用法如下。
Range range;
Range rangeCell;
_variant_t var;
range.AttachDispatch(usedRange.GetCells());
rangeCell.AttachDispatch(range.GetItem(COleVariant((long)ii),COleVariant((long)jj)).pdispVal);
var = rangeCell.GetValue2();
rangeCell.ReleaseDispatch();
range.ReleaseDispatch();
- VC++操作EXCEL内存泄露问题
- VC 读取操作Excel问题
- VC检查内存泄露
- vc内存泄露检查
- VC++内存泄露定位
- VC内存泄露检测
- VC调试内存泄露
- VC 内存泄露
- VC内存泄露定位
- VC内存泄露检测
- VC检测内存泄露
- VC 内存泄露查找
- VC++内存泄露定位
- vc ado 内存泄露
- VC检测内存泄露
- VC检测内存泄露
- VC++内存泄露检查
- VC内存泄露检测
- 悠悠的时光里,喜欢静守着一份淡然,
- Android studio导入eclipse项目报错Cause: error in opening zip file解决方法
- android 已省内存方式把图片加载到内存
- android三档自定义滑动开关,禁止点击功能的实现,用默认的seekbar组件实现
- ubuntu 64位环境
- VC++操作EXCEL内存泄露问题
- Eclipse_如何设置注释模板
- 皮尔逊相关度系数原理,以及java实现
- C语言标准发展历
- 程序发布为应用程序
- 应聘互联网公司的简历应该是怎么样的?
- "ORA-00942: 表或视图不存在 "的原因和解决方法
- Cocos2d-x + Android + Eclipse + Windows 8
- 使用echarts简单制作中国地图