前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >升级到 dotnet core 之后 HandleProcessCorruptedStateExceptions 无法接住异常

升级到 dotnet core 之后 HandleProcessCorruptedStateExceptions 无法接住异常

作者头像
林德熙
发布2021-01-29 10:17:56
8060
发布2021-01-29 10:17:56
举报
文章被收录于专栏:林德熙的博客林德熙的博客

这是 dotnet core 的破坏性改动之一,在 dotnet framework 里面,可以使用 HandleProcessCorruptedStateExceptionsAttribute 接住非托管层抛出的异常,如 C++ 异常等。但是这个功能在 dotnet core 下存在行为的变更,从 .NET Core 1.0 开始,损坏进程状态异常无法由托管代码进行处理。 公共语言运行时不会将损坏进程状态异常传递给托管代码

如果逻辑代码完全使用 C# 实现,那么应用程序可以称为是安全的。这里的安全指的是内存安全。这是 dotnet 的一个优势,在于异常处理上,和 C++ 等的异常处理不同的是,很少会有异常能让整个程序闪退。可以很方便在应用程序里面接住软件运行异常,然后通过各个方法让软件继续执行

但如果 C# 调用了 C++ 的库,那就不好玩了,这就意味着如果 C++ 的库如果实现不够好的话,那么这个库是能带着整个应用程序闪退的。而有趣的是,其实我到现在还没遇到几个团队写出的 C++ 库是稳定的,基本上通过我的 DUMP 分析可以看到,每多加一个 C++ 库,软件的稳定性就下降一半。好在,有一些 C++ 库抛出来的异常,咱勉强还是能接住的,至少不会让整个应用程序就闪退了

接住 C++ 异常的其中一个方法就是通过 HandleProcessCorruptedStateExceptions 特性,在方法上面标记 HandleProcessCorruptedStateExceptions 特性,此时在方法里面使用 try catch 是可以接住大部分的 C++ 异常的,如 System.AccessViolationException 异常

请看下面代码

代码语言:javascript
复制
        [HandleProcessCorruptedStateExceptions]
        static void Main(string[] args)
        {
            try
            {
                Console.WriteLine(HeederajiYeafalludall());
            }
            catch (Exception e)
            {
                Console.WriteLine(e);
            }
        }

        [DllImport("BeyajaydahifallChecheecaifelwarlerenel.dll")]
        static extern Int16 HeederajiYeafalludall();

上面代码的 HeederajiYeafalludall 方法是由 BeyajaydahifallChecheecaifelwarlerenel.dll 提供的,这是一个由 C++ 写的库,在这里面的实现将会出现越界

代码语言:javascript
复制
extern "C" __declspec(dllexport) int HeederajiYeafalludall() 
{
    int* p = (int*)123;
    while (true)
    {
        *p = 123;
        p++;
    }

    return 123;
}

在标记了 HandleProcessCorruptedStateExceptionsAttribute 特性之后,将可以看到断点能进入到 catch 代码里,而且程序不会闪烁退

但是这个机制在 dotnet core 就跑不起来了,根据 从 .NET Framework 到 .NET Core 的中断性变更 文档,可以看到在 .NET Core 1.0 开始,损坏进程状态异常无法由托管代码进行处理,将上面的 C# 代码切换到 dotnet core 下执行,此时将会发现不会进入到 catch 的代码,应用程序将会退出

大家可以尝试使用我放在 github 的代码进行测试,切换框架为 .NET Framework 和 .NET Core 比较这里的行为


本文会经常更新,请阅读原文: https://blog.lindexi.com/post/%E5%8D%87%E7%BA%A7%E5%88%B0-dotnet-core-%E4%B9%8B%E5%90%8E-HandleProcessCorruptedStateExceptions-%E6%97%A0%E6%B3%95%E6%8E%A5%E4%BD%8F%E5%BC%82%E5%B8%B8.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档