Excel在.Net下驻留内存的解决方法.net -电脑资料

电脑资料 时间:2019-01-01 我要投稿
【www.unjs.com - 电脑资料】

    这段时间在VS 2003的WebForm. 方式下对Excel 进行操作,遇到一个最为头疼的问题就是对Excel操作完毕后Excel不能够正常关闭,系统退出后,Excel总是驻留在内存中,

Excel在.Net下驻留内存的解决方法.net

。但是这段代码放到WinForm的程序中又没有问题。在网上进行了查找也没有找到有效可行的办法。经过

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

    原来书写如下:

    <PRE></p><p>    private Excel.Application m_app;</p><p>    private Excel.Workbook m_workbook;</p><p>    this.m_app = new Excel.ApplicationClass();</p><p>    this.m_app.DisplayAlerts = false;</p><p>    this.m_workbook = this.m_app.Workbooks.Open(sFilePath, Missing.Value,</p><p>    Missing.Value, Missing.Value, Missing.Value,</p><p>    Missing.Value, Missing.Value, Missing.Value,</p><p>    Missing.Value, Missing.Value, Missing.Value,</p><p>    Missing.Value, Missing.Value, Missing.Value,</p><p>    Missing.Value );</p></PRE>

    修改后如下:

    <PRE></p><p>    private Excel.Application m_app;</p><p>    private Excel.Workbooks m_workbooks;</p><p>    private Excel.Workbook m_workbook;</p><p>    this.m_app = new Excel.ApplicationClass();</p><p>    this.m_app.DisplayAlerts = false;</p><p>    m_workbooks = this.m_app.Workbooks;</p><p>    this.m_workbook = this.m_workbooks.Open(sFilePath, Missing.Value,</p><p>    Missing.Value, Missing.Value, Missing.Value,</p><p>    Missing.Value, Missing.Value, Missing.Value,</p><p>    Missing.Value, Missing.Value, Missing.Value,</p><p>    Missing.Value, Missing.Value, Missing.Value,</p><p>    Missing.Value );</p></PRE>

    同样对Sheet的操作如下:

    修改前如下:

    <PRE></p><p>    Excel._Worksheet worksheet1 = null;</p><p>    worksheet1 = (Excel._Worksheet) this.m_workbook.Worksheets.get_Item(sSheetName);</p><p>    修改后如下:</p><p>    Excel.Sheets sheets = null ;</p><p>    Excel._Worksheet worksheet1 = null;</p><p>    sheets = this.m_workbook.Worksheets;</p><p>    worksheet1 = (Excel._Worksheet) sheets.get_Item(sSheetName);</p></PRE>

    发现区别了吗?原来Workbooks,Worksheets这两个类没有被实例化就直接使用了,造成该类不能够被回收,

电脑资料

Excel在.Net下驻留内存的解决方法.net》(https://www.unjs.com)。最终造成Excel在内存的驻留。

    最终以如下方式释放。

    <PRE></p><p>    private void ReleaseAllRef(Object obj)</p><p>    {</p><p>    try</p><p>    {</p><p>    if (obj != null )</p><p>    {</p><p>    while (Marshal.ReleaseComObject(obj) > 1);</p><p>    }</p><p>    }</p><p>    finally</p><p>    {</p><p>    bj = null;</p><p>    }</p><p>    }</p><p>    private void Release()</p><p>    {</p><p>    if (m_app != null )</p><p>    {</p><p>    m_app.Quit() ;</p><p>    }</p><p>    ReleaseAllRef(m_workbook) ;</p><p>    m_workbook = null ;</p><p>    ReleaseAllRef(m_workbooks) ;</p><p>    m_workbooks = null ;</p><p>    ReleaseAllRef(m_app) ;</p><p>    m_app = null ;</p><p>    System.GC.Collect() ;</p><p>    }</p></PRE>

    【责任编辑:火凤凰 TEL:(010)68476606-8007】

    原文转自:http://www.ltesting.net

最新文章