Excel在.Net 环境下Web方式下驻留内存问题的解决

这段时间在VS 2003 WebForm 方式下对Excel 进行操作,遇到一个最为头疼的问题就是对Excel操作完毕后Excel不能够正常关闭,系统退出后,Excel总是驻留在内存中。但是这段代码放到WinForm的程序中又没有问题。在网上进行了查找也没有找到有效可行的办法。经过无数次的尝试,终于解决如下:

原来书写如下:

private Excel.Application m_app;

private Excel.Workbook m_workbook;

this.m_app = new Excel.ApplicationClass();

this.m_app.DisplayAlerts = false;

this.m_workbook = this.m_app.Workbooks.Open(sFilePath, Missing.Value, 

              Missing.Value, Missing.Value, Missing.Value, 

              Missing.Value, Missing.Value, Missing.Value, 

              Missing.Value, Missing.Value, Missing.Value, 

              Missing.Value, Missing.Value, Missing.Value,

            Missing.Value );

修改后如下:

private Excel.Application m_app;

private Excel.Workbooks m_workbooks;

private Excel.Workbook m_workbook;

this.m_app = new Excel.ApplicationClass();

this.m_app.DisplayAlerts = false;

m_workbooks = this.m_app.Workbooks;

this.m_workbook = this.m_workbooks.Open(sFilePath, Missing.Value, 

              Missing.Value, Missing.Value, Missing.Value, 

              Missing.Value, Missing.Value, Missing.Value, 

              Missing.Value, Missing.Value, Missing.Value, 

              Missing.Value, Missing.Value, Missing.Value,

            Missing.Value );

 

同样对Sheet的操作如下

修改前如下:

Excel._Worksheet worksheet1 = null;

worksheet1 = (Excel._Worksheet) this.m_workbook.Worksheets.get_Item(sSheetName);

修改后如下:

Excel.Sheets sheets = null ;

Excel._Worksheet worksheet1 = null;

sheets = this.m_workbook.Worksheets;

worksheet1 = (Excel._Worksheet) sheets.get_Item(sSheetName);

发现区别了么?原来WorkbooksWorksheets这两个类没有被实例化就直接使用了,造成该类不能够被回收。最终造成Excel在内存的驻留。

最终以如下方式释放。

private void ReleaseAllRef(Object obj)

{

try

              {

              if (obj != null )

                            {

                                          while (Marshal.ReleaseComObject(obj) > 1);

                            }

              }

              finally

              {

                            obj = null;

              }

}

private void Release()

{

              if (m_app != null )

              {

                            m_app.Quit() ;

              }

              ReleaseAllRef(m_workbook) ; 

              m_workbook = null ; 

              ReleaseAllRef(m_workbooks) ; 

              m_workbooks = null ; 

              ReleaseAllRef(m_app) ; 

              m_app = null ; 

              System.GC.Collect() ;

}
 

转载于:https://www.cnblogs.com/leonardleonard/archive/2007/03/21/1928196.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值