转发:
由于有些非托管的DLL内部异常未有效处理,当托管程序调用到这样的DLL时,就引起托管程序意外退出。
托管程序使用通常的捕获try……catch块不起作用。原因是.NET 4.0里新的异常处理机制引起。
在4.0以前,因为SEH异常被转换成了跟普通.NET异常相同的异常,这样程序员只要用catch ( Exception e)的模式就可以捕捉到所有的异常。这样处理的问题是,由于SEH异常通常都不是托管代码抛出的,托管代码根本就不知道SHE异常被扔出来的原因,简单的catch ( Exception e)处理使得整个程序会处于一个非常不稳定的状态,使得前面被忽略的问题在后面以更严重的方式出现 — 例如保存被破坏的数据。这样,看起来使用catch ( Exception e)处理所有的异常的方法很简单,但实际上让程序员或者用户在问题延后发生时,分析起来需要花费更多的精力。
在托管程序中捕获非托管程序异常,需要在函数外面加一个HandleProcessCorruptedStateExceptions属性标记,如下示例:
using System.Runtime.ExceptionServices; [HandleProcessCorruptedStateExceptions] public static int GetInfo() { try { //产生非托管异常函数 } catch (Exception ex) { //异常处理 } }
这样在调用自己写的方法GetInfo()时,如果发生非托管的异常,就会跑到异常处理块中,剩下的事情就好办了。
文章评论