C#调用COM组件后退出Excel进程
我在使用WinForm程序调用Excel的COM组件的时候,也遇到了Excel进程退出的问题。这个问题很多人已经遇到,而且解决办法也吵得很热。
现在总结一下:
第一种方法是调用相关的组件释放方法,然后用代码调用垃圾收集器进行处理。这种方法比较正常,也就是说,是通过正规渠道来退出这个进程。
[csharp]
public void QuitExcel(Microsoft.Office.Interop.Excel.Application application)
{
application.Quit();
try
{
System.Runtime.InteropServices.Marshal.ReleaseComObject(application);
}
catch (System.Exception ex)
{
MessageBox.Show(ex.ToString());
}
finally
{
application = null;
GC.Collect();
}
}
第二种方法是强制Kill相关的Excel进程。因为第一种方法可能会跟相关的环境有关,在有的机器上能够成功,而在某些机器上可能不会成功,所以,这时提出了一种比较尖锐的做法,那就是找到这个ExcelApplication相关的进程,然后强制杀掉。但是,这毕竟不是常规的退出某个进程的方法,不知道会不会造成内存碎片等问题,如果不是其他方式都不好用的话,不推荐使用
[csharp]
[DllImport("User32.dll", CharSet = CharSet.Auto)]
public static extern int GetWindowThreadProcessId(IntPtr hwnd, out int ID);
public static void Kill(Microsoft.Office.Interop.Excel.Application excel)
{
excel.Quit();
IntPtr t = new IntPtr(excel.Hwnd);
int k = 0;
GetWindowThreadProcessId(t, out k);
System.Diagnostics.Process p = System.Diagnostics.Process.GetProcessById(k);
p.Kill();
}
这里还有一点要提出的是,如果调用的COM组件所依附的应用程序退出的话,不管有没有对Excel进程进行额外的处理,这个Excel进程都会退出的。比如说,我使用的是WinForm程序调用的COM组件。现在我处理完Excel后,并没有处理Excel进程,而是直接点右上角的X关闭这个应用程序,那么Excel进程也就退出了。但是需要指出的是,很多WinForm程序并不是处理完Excel就要关闭的,还要进行很多额外的其他工作,所以,就有必要处理相关的Excel进程了。而且,如果是Web程序的话,会一直运行,如果不进行处理的话,这个Excel进程会一直存在。
补充:软件开发 , C# ,