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

本文介绍了一种在.NET应用程序中使用Excel对象后正确释放资源的方法。主要步骤包括:创建ExcelApplication实例,确保对象不可见;实现IDisposable接口来定义Dispose方法,在该方法中调用appExcel.Quit()关闭Excel,并通过Marshal.ReleaseComObject释放COM对象;最后,在不再使用对象时手动调用Dispose方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

以前写过一个小东西,功能是通过网页上传一个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); 
      }
     }
    dot.gif
    GC.Collect();
  }
  dot.gif
}

3. 注意,最后一定要手动调用Dispose方法。
posted on 2006-06-16 11:15 Vincent.Hu 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/sainthn/archive/2006/06/16/427298.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值