.net4.0调用非托管DLL的异常捕获

本文介绍了在.NET 4.0及以后版本中处理非托管DLL内部异常的方法。由于新的异常处理机制,直接使用try...catch无法捕获这些异常。文章提供了一个示例,展示了如何通过使用HandleProcessCorruptedStateExceptions属性来解决此问题。

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

 

由于有些非托管的DLL内部异常未有效处理,当托管程序调用到这样的DLL时,就引起托管程序意外退出。

托管程序使用通常的捕获try……catch块不起作用。原因是.NET 4.0里新的异常处理机制引起。

在4.0以前,因为SEH异常被转换成了跟普通.NET异常相同的异常,这样程序员只要用catch ( Exception e)的模式就可以捕捉到所有的异常。这样处理的问题是,由于SEH异常通常都不是托管代码抛出的,托管代码根本就不知道SHE异常被扔出来的原因,简单的catch ( Exception e)处理使得整个程序会处于一个非常不稳定的状态,使得前面被忽略的问题在后面以更严重的方式出现 — 例如保存被破坏的数据。这样,看起来使用catch ( Exception e)处理所有的异常的方法很简单,但实际上让程序员或者用户在问题延后发生时,分析起来需要花费更多的精力。

在托管程序中捕获非托管程序异常,需要在函数外面加一个HandleProcessCorruptedStateExceptions属性,如下示例:

[HandleProcessCorruptedStateExceptions]
public static int GetInfo()

{

try{

        //产生非托管异常函数

        UnmanagedMethod();

}

catch(Exception ex)

{

//异常处理

}

}

这样在调用自己写的方法GetInfo()时,如果发生非托管的异常,就会跑到异常处理块中,剩下的事情就好办了。

 

参考文章:http://www.cnblogs.com/Terry-greener/archive/2011/11/29/2268052.html

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值