您的位置:首页 > 编程语言 > C语言/C++

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

2014-12-12 15:57 295 查看
一般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