前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Excel在.Net 环境下Web方式下驻留内存问题的解决

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

作者头像
Java架构师必看
发布2021-03-22 11:26:21
2710
发布2021-03-22 11:26:21
举报
文章被收录于专栏:Java架构师必看

这段时间在VS 2003 的WebForm 方式下对Excel 进行操作,遇到一个最为头疼的问题就是

这段时间在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);

发现区别了么?原来Workbooks,Worksheets这两个类没有被实例化就直接使用了,造成该类不能够被回收。最终造成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() ;

}

本文由来源 21aspnet,由 javajgs_com 整理编辑,其版权均为 21aspnet 所有,文章内容系作者个人观点,不代表 Java架构师必看 对观点赞同或支持。如需转载,请注明文章来源。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档