彻底斩杀被调用的COM+进程,一个字.....kill()

本文详细介绍了在ASP.NET中使用Excel COM对象处理业务后,如何正确回收资源,避免内存泄漏的问题。作者分享了一段代码,用于在操作完成后关闭并释放Excel对象,并探讨了在用户异常关闭浏览器时,如何确保资源得到妥善回收。

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

其实好几天前就想写完这篇博客,因为事情太多。今天才拿出代码来,回故一下。赶快补上。。。。。

 

以下是在aspx的页面里,调用excel来处理业务后,用完后。回收excel进程的代码:

 

ContractedBlock.gifExpandedBlockStart.gif代码
if (excel != null)
{
try
{
int hwnd = excel.Hwnd;

if (book != null)
{
book.Close(
true, Missing, Missing);
Marshal.ReleaseComObject(book);
book
= null;
}

excel.Workbooks.Close();
excel.Quit();
Marshal.ReleaseComObject(excel);
excel
= null;
GC.Collect(
20);

int processID = GetWindowThreadProcessId(hwnd);
if (processID != 0)
{
Process process
= Process.GetProcessById(processID);
process.Kill();
}
}
catch
{
}
}

 

但是。我最近发现,如果页面正在执行中。Ka的一下,把网页关了。excel.exe这个进程会一直在内存中。而且回收IIS应用程序池或是等比较长时间或是再次进行excel。哪个之前挂的excel.exe会一直在。

最后,我发现。是因为异常关闭IE,对于aspx页面,没有能很好的回收进程。所以我在每次调用excel之时,手动进行一次GC回收,

GC.Collect()

 


转载于:https://www.cnblogs.com/pctzhang/archive/2010/04/15/1712431.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值