我目前正在尝试为外部启动的进程(不是从visual studio中启动)启动调试器。我似乎无法让调试器真正启动,因为它似乎什么都没有发生。在此过程中,我添加了以下代码:
Debug.Assert(Debugger.IsAttached == false, "Should be no debugger");
if (!Debugger.IsAttached)
{
Debug.Assert(Debugger.Launch(), "Debugger not launched");
}
Debugger.Break();
Debug.Assert(Debugger.IsAttached == true, "Debugger should be attached");这些断言是为了证实我没有疯。首先,正如我所预期的那样,IsAttached属性返回false。然后我调用Debugger.Launch,然后返回true。根据Debugger.Launch的MSDN文档,它表示只有在成功启动调试器或已附加调试器时才会返回true。我证实一个没有附加,所以它肯定是发射了一个。
中断点永远不会被击中,第二个验证失败( IsAttached属性返回false)。我还试图在Debugger.Launch之后睡上一觉,让它有一段时间,但没有效果。
有什么建议吗?
发布于 2014-10-06 17:42:32
发布于 2013-12-09 04:31:01
这是一个蹩脚的答案,因为我在问题中找不到任何关于VS Express的参考,而且我在使用VS2013 Pro时也遇到了同样的问题。
尽管这文章sais在VS2013中解决了这个问题,即使您像我一样使用VS2013,也要查找上面列出的临时修复选项卡。我用它解决了问题。链接中有更多信息。
我只想把另一篇文章链接到正确的方向,也许它也是有用的。
HKEY_CLASSES_ROOT\AppID{E62A7A31-6025-408E-87F6-81AEB0DC9347}摘要:将Visual实时调试器注册表项的AppIDFlags值从0x28更改为0x8 (或根据上面的文章,试错),它们的注册表项为。
发布于 2015-07-15 23:16:56
也许这会对未来的人有所帮助。我也有同样的问题,Debugger.Launch似乎什么也没做。原来是其他人登录到我的机器上,调试器附件在他们的环境中被提示启动,而不是我的。我把他们踢出了系统,然后就修好了。
https://stackoverflow.com/questions/12655965
复制相似问题