c# - 在奇怪的情况下抛出 AccessViolationException

标签 c# asp.net .net iis access-violation

我在 C# 中使用了很长时间,但我从未遇到过这种错误。首先,您是否看到关于这个单个代码块的任何错误(可能是错误的)(当然除了它的逻辑,我知道它总是返回 0)?

public static int GetDecimals(MySimpleEnum val)
    {
        int result = 0;
        switch (val)
        {
            case MySimpleEnum.Base:
            case MySimpleEnum.Slow:
            case MySimpleEnum.Normal:
            case MySimpleEnum.Quick:
            case MySimpleEnum.Fastest:
                result = 0;
                break;
        }            
        return result;        
    }

Release project settings: DEBUG constant = false; TRACE constant = true; Optimize Code = true; Output/Advanced/Debug info = none;

IIS = version 7.5

此方法具有指定的发布设置,抛出“System.AccessViolationException:尝试读取或写入 protected 内存。这通常表示其他内存已损坏。”

这是有趣的部分。这些是当它不抛出此异常时的情况:

  1. 在 IIS(Express 和非 Express)8.5 上运行它(无需编辑项目)。
  2. 设置优化代码= false;和输出/高级/调试信息 = false;
  3. 将方法包装在 try/catch block 中(还尝试在 catch block 中使用 log4net 记录异常 - 空日志)
  4. 用一些不同的代码替换方法的内部。

注意事项:

  • 必须使用服务器上的 win 调试器捕获异常(没有 调用了常规 .NET 异常处理程序)
  • 异常后应用程序崩溃。
  • 这个代码块在几个月前就可以运行了(很长一段时间没有发布)。该错误可能始于某些更新。
  • 在两台装有 IIS 7.5 的不同服务器和一台装有 IIS 8.5 和 IIS Express (VS2012) 的机器上进行了测试。结果相同。
  • 我尝试了很多不同的项目设置组合。基本上,如果我没有像第 2 点那样进行设置,它会抛出 IIS 7.5 异常。
  • 我的工作(和构建)机器运行的是具有最新更新的 Windows 8.1。
  • 代码块位于单独的项目(类库)中。

我知道如何解决这个问题。但我不喜欢在不知道原因的情况下关闭问题。另外,我想将来避免这种情况。你觉得你能帮我吗?如果它是一些空引用异常,为什么会发生这种情况?为什么它是特定于调试/发布或特定于 IIS 版本的?

*注2:

最近我在发布时遇到了缺少 dll(System.Net.Http.Formatting.dll、System.Web.Http.dll、System.Web.Http.WebHost.dll)的问题。这是因为某些 Microsoft 安全更新。也许这是类似的东西。*

编辑 1 添加枚举声明的结构。

public enum MySimpleEnum
    {
        Base = 0,
        Slow = 1,
        Normal = 2,
        Quick = 3,
        Fastest = 4
    }

此外,我刚刚尝试添加 [MethodImpl(MethodImplOptions.NoInlining)],但没有帮助。

最佳答案

托管代码中出现这些类型的访问冲突错误是不常见的。它们来自内存损坏,这可能表明硬件出现故障 - 在极少数情况下,这表明 CLR 本身存在错误。

此类错误最有可能的原因来自其他地方,例如如果此代码以某种方式使用 native 代码 - 在不安全的上下文中调用 native 代码或从 native 代码调用。

引用MSDN AccessViolationException :

In programs consisting entirely of verifiable managed code, all references are either valid or null, and access violations are impossible. An AccessViolationException occurs only when verifiable managed code interacts with unmanaged code or with unsafe managed code.

在任何情况下,您通常都需要查看代码中的其他地方以找到破坏内存的错误代码。不幸的是,这是一个很难解决的问题。祝你好运!

关于c# - 在奇怪的情况下抛出 AccessViolationException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27281637/

相关文章:

c# - 如何从access数据库中获取多行数据

c# - 如何从 C# 显示 "Display Settings"窗口

javascript - 从定义的 <td> 获取值 (ASP.NET MVC)

c# - 为什么这种扩展方法不起作用?

c# - 如何上下移动列表框中的项目?

c# - WPF/银光 : How to convert hex value into Color?

在另一个类中发送的 c# 数组发回零

asp.net - 当错误页面本身卡在asp.net mvc3中时如何处理?

c# - '找不到文件 ... bin\roslyn\csc.exe'

c# - 该接口(interface)是否已存在于标准 .NET 库中?