VC++操作EXCEL内存泄露问题


一般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();

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值