设为首页
加入收藏
站内地图
旧版入口
当前位置:首页 > 站长学院 > 网络编程 > ASP.NET

关于解决在.Net中调用Excel对象后关闭Excel进程的问题

作者:佚名 出处:网络转载 时间:06-17 点击:

内容载入中...
欢迎向提供原创教程 upschool.com.cn

以前写过一个小东西,功能是通过网页上传一个xls文件,后台自动将数据导入到数据库中。至于整个业务逻辑没什么新鲜的,我觉得需要记录下来的是如何在完成数据导入以后释放资源,备忘!

1. 创建Excel application

private Microsoft.office.Interop.Excel.Application appExcel;
appExcel 
= new Microsoft.office.Interop.Excel.ApplicationClass();
appExcel.Visible 
= false;

2. 实现IDisposable

public void Dispose()
{
  Dispose(
true);
  GC.SuppressFinalize(
this);
}

private void Dispose(bool disposing)
{
  
if(!this.bDisposed)
  {
    
if(disposing)
    {
      
if(appExcel != null)
      {
    appExcel.Quit();
    
//释放COM组件,其实就是将其引用计数减1
    System.Runtime.InteropServices.Marshal.ReleaseComObject(appExcel); 
      }
     }
    
    GC.Collect();
  }
  
}

3. 注意,最后一定要手动调用Dispose方法。
收藏本文:
】【打印页面】【推荐给朋友】【关闭窗口

站长学院

推荐信息