c# 捕获非托管异常

本文介绍了在.NET Framework 4.0及更高版本中CLR如何处理标记为破坏性的SEH异常,并提供了两种解决方案:一是通过配置文件启用legacyCorruptedStateExceptionsPolicy;二是使用HandleProcessCorruptedStateExceptions属性。

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

在.NET 4.0之后,CLR将会区别出一些异常(都是SEH异常),将这些异常标识为破坏性异常(Corrupted State Exception)。针对这些异常,CLR的catch块不会捕捉这些异常。SEH异常通常是非托管代码抛出的。

例如:调用c和c++的lib和dll库,都是非托管的。

解决:

1.在托管程序的.config文件里,启用legacyCorruptedStateExceptionsPolicy这个属性,即简化的.config文件类似下面的文件:

<?xml version="1.0"?>
<configuration>
 <startup>
   <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0"/>
 </startup>
    <runtime>
      <legacyCorruptedStateExceptionsPolicy enabled="true" />
    </runtime>
</configuration>

2.在需要捕捉破坏性异常的函数外面加一个HandleProcessCorruptedStateExceptions属性,这个属性只控制一个函数,对托管程序的其他函数没有影响

[HandleProcessCorruptedStateExceptions]
 void function()
 {
     try
     {
     }
     catch (Exception e)
     {
     }
 }

 

转载于:https://www.cnblogs.com/yaosj/p/6604891.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值