在切换'首选32位时 - 使用64位操作系统上的接口和泛型的奇怪调试器行为

Ste*_*ley 20 c# generics anycpu .net-4.5

我也碰到过这种奇怪的行为:当我的项目设置设为Any CPUPrefer 32-bit64bit Windows 7 OS.Net 4.5下面的工程计划符合市场预期.然而,如果我关闭Prefer 32-bit然后在单步执行程序时,我可以看到代码从不进入接口实现 - 但也不会抛出任何错误.

我在以下控制台应用程序中将其简化为最简单的形式:

namespace BugCheck
{
    interface IBroken
    {
        bool Broken<TValue> (TValue gen, Large large);
    }
    class Broke : IBroken
    {
        public bool Broken<TValue> (TValue gen, Large large )
        { return true; }
    }
    struct Large
    {
        int a, b, c;
    }
    class Program
    {
        static void Main (string[] args)
        {
            //32bit can step in. 64bit can't
            ((IBroken)new Broke()).Broken(1, new Large());
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

正如预期的那样,当切换Prefer 32-bit程序时,将在.net 32​​位程序集和64位程序集之间交替 - 它在32位程序集中按预期工作,并在64位程序集中"静默地".

正如@Athari所建议的那样,它似乎与Large结构的大小有关.

我做错了导致这种行为的原因是什么?

cos*_*ost 1

对于那些遇到这个问题并寻求解决方案的人,引用Microsoft 团队的 Tom 的话话:

\n\n
\n

这看起来与 .NET Framework 4.5.2 中修复的错误有关。我们可以通过禁用托管返回值功能来验证该问题是否相关。我已将执行此操作的说明发布到“解决方法”部分。

\n\n

此问题是由收集返回值的代码引起的。可以通过禁用托管返回值来解决该问题。

\n\n
    \n
  1. 进入系统属性(Win8:WinKey+X,选择\xe2\x80\x98System\xe2\x80\x99,Win7:从我的电脑打开\xe2\x80\x98Properties\xe2\x80\x99)
  2. \n
  3. 高级系统设置
  4. \n
  5. 环境变量\xe2\x80\xa6
  6. \n
  7. 单击 \xe2\x80\x98New\xe2\x80\x99 并添加 \n
      \n
    • 名称:VSDebug_DisableManagedReturnValue
    • \n
    • 值:1
    • \n
  8. \n
\n\n

如果禁用托管返回值可以解决该问题,则该问题的修复程序位于 .NET Framework 4.5.2 中。可以从以下位置下载\n http://www.microsoft.com/en-us/download/details.aspx?id=42642下载该文件。\n 只需安装 4.5.2 即可解决该问题。

\n
\n