在 Visual Studio 中使用 Just-In-Time 调试器进行调试
当一个在 Visual Studio 之外运行的应用发生错误或崩溃时,实时调试可自动启动 Visual Studio。 只需进行In-Time 调试,您即可在 Visual Studio 以外测试应用程序,并在出现问题时打开 Visual Studio 开始调试。
实时调试适用于 Windows 桌面应用。 它不适用于通用 Windows 应用,也不适用于托管在本机应用程序(如可视化工具)中的托管代码。
小贴士
如果只想让实时调试器对话框停止显示,而不安装 Visual Studio,请参阅禁用实时调试器。 如果已安装 Visual Studio,可能需要从 Windows 注册表禁用实时调试。
在 Visual Studio 中启用或禁用实时调试
可以在 Visual Studio 工具>选项(或 调试>选项)对话框中配置 Just-In-Time 调试。
注释
若要启用或禁用实时调试,必须以管理员身份运行 Visual Studio。 启用或禁用 Just-In-Time 调试会设定注册表键值,可能需要管理员权限才能更改该键。 若要以管理员身份打开 Visual Studio,请右键单击 Visual Studio 应用,然后选择 以管理员身份运行。
启用或禁用实时调试:
在“工具”或“调试”菜单上,选择“选项”>“调试”>“实时”。
注释
如果未显示 Just-In-Time 菜单选项,请确保使用 Visual Studio 安装程序安装 Just-In-Time 调试器。
在“为这些类型的代码启用实时调试”框中,选择希望通过实时调试进行调试的代码类型:“托管”、“本机”和/或“脚本”。
选择“确定”。
如果启用了实时调试器,但它并未在应用程序崩溃或出错时打开,请参阅排查实时调试问题。
从 Windows 注册表禁用实时调试
即便计算机中不再安装有 Visual Studio,仍可启用实时调试。 如果不再安装 Visual Studio,可以通过编辑 Windows 注册表来禁用 Just-In-Time 调试。
若要通过编辑注册表禁用实时调试,请执行以下操作:
在 Windows “开始”菜单中,运行 注册表编辑器(regedit.exe)。
在 注册表编辑器 窗口中,找到并删除以下注册表项(如果存在):
HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Windows NT\CurrentVersion\AeDebug\Debugger
HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\.NETFramework\DbgManagedDebugger
如果存在以下注册表项,请将其删除:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\AeDebug\Debugger
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\.NETFramework\DbgManagedDebugger
请确保不要删除或更改任何其他注册表项。
关闭 注册表编辑器 窗口。
启用 Windows 窗体的实时调试
默认情况下,Windows 窗体应用具有顶级异常处理程序,允许应用在可以恢复时继续运行。 如果 Windows 窗体应用引发未经处理的异常,则会显示以下对话框:
若要启用 Just-In-Time 调试模式而不是标准的 Windows 窗体错误处理,请添加以下设置:
在 machine.config 或 <应用名称>.exe.config 文件的
system.windows.forms
部分中,将jitDebugging
值设置为true
:<configuration> <system.windows.forms jitDebugging="true" /> </configuration>
在 C++ 窗体应用程序中,还要在 .config 文件或代码中将
DebuggableAttribute
设置为true
。 如果使用 /Zi 进行编译,并且不使用 /Og,编译器会为你设置此属性。 但是,如果要调试非优化发布版本,则必须通过在应用的 AssemblyInfo.cpp 文件中添加以下行来设置DebuggableAttribute
:[assembly:System::Diagnostics::DebuggableAttribute(true, true)];
有关详细信息,请参阅 DebuggableAttribute。
使用实时调试
本示例将指导你在应用程序引发错误时进行 Just-In-Time 调试。
必须安装 Visual Studio 才能执行以下步骤。 如果没有 Visual Studio,可以下载免费的 Visual Studio Community Edition。
请务必依次选择“工具”>“选项”>“调试”>“实时”,启用实时调试。
在本示例中,你在 Visual Studio 中创建一个 C# 控制台应用,该应用引发 NullReferenceException。
在 Visual Studio 中,创建一个名为 ThrowsNullException 的 C# 控制台应用(“文件”>“新建”>“项目”>“Visual C#”>“控制台应用程序”)。 有关在 Visual Studio 中创建项目的详细信息,请参阅 演练:创建简单的应用程序。
在 Visual Studio 中打开项目时,打开 Program.cs 文件。 将 Main() 方法替换为以下代码,该代码将一行输出到控制台,然后引发 NullReferenceException:
static void Main(string[] args) { Console.WriteLine("we will now throw a NullReferenceException"); throw new NullReferenceException("this is the exception thrown by the console app"); }
若要生成解决方案,请选择 调试(默认)或 发布 配置,然后选择 生成>重新生成解决方案。
有关生成配置的详细信息,请参阅 了解生成配置。
在 C# 项目文件夹中打开生成的应用 ThrowsNullException.exe(...\ThrowsNullException\ThrowsNullException\bin\Debug 或 ...\ThrowsNullException\ThrowsNullException\bin\Release)。
应会看到以下命令窗口:
“选择实时调试器”对话框将打开。
在“可用调试器”下,选择“<首选 Visual Studio 版本> 的新实例”(如果尚未选择)。
选择“确定”。
ThrowsNullException 项目将在 Visual Studio 的新实例中打开,执行在引发异常的行处停止:
此时可以开始调试。 如果要调试实际应用,则需要了解代码引发异常的原因。
注意
如果应用包含不受信任的代码,将显示一个安全警告对话框,使你能够决定是否继续调试。 在继续调试之前,请决定是否信任代码。 你自己编写了代码吗? 如果应用程序在远程计算机上运行,是否识别进程的名称? 如果应用在本地运行,请考虑在计算机上运行的恶意代码的可能性。 如果决定信任该代码,请选择“确定”。 否则,请选择“取消”。
排查实时调试问题
如果在应用崩溃时实时调试不启动,即使 Visual Studio 中已启用实时调试也是如此,则:
已知 Windows 问题可能会导致 Just-In-Time 调试器失败。
修复方法是向以下注册表项添加值为“自动”的“DWORD 值”,以及值为“1”的“数值数据”:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\AeDebug
(对于 64 位计算机上的 32 位应用) HKEY_LOCAL_MACHINE\Software\WOW6432Node\Microsoft\Windows NT\CurrentVersion\AeDebug
Windows 错误报告可能会接管计算机上的错误处理。
若要修复此问题,请使用注册表编辑器向以下注册表项添加值为“已禁用”的“DWORD 值”,以及值为“1”的“数值数据”:
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\Windows Error Reporting
(对于 64 位计算机上的 32 位应用) HKEY_LOCAL_MACHINE\Software\WOW6432Node\Microsoft\Windows\Windows Error Reporting
有关详细信息,请参阅 .WER 设置。
在 Just-In-Time 调试过程中,您可能会看到以下错误消息:
无法附加到故障进程。 指定的程序不是 Windows 或 MS-DOS 程序。
调试器尝试附加到由其他用户运行的进程。
若要解决此问题,请在 Visual Studio 中打开 “调试>附加到进程”(或 按 Ctrl + Alt + P),并在 可用进程 列表中找到要调试的进程。 如果不知道进程的名称,可在 Visual Studio Just-In-Time 调试器 对话框中找到进程 ID。 选择 可用进程 列表中的进程,然后选择 附加。 选择“否”可关闭“实时调试器”对话框。
无法启动 调试器,因为没有用户登录。
没有用户登录到控制台,因此没有用户会话来显示 Just-In-Time 调试对话框。
若要解决此问题,请登录到计算机。
类没有注册。
调试器尝试创建未注册的 COM 类,可能是由于安装问题。
若要解决此问题,请使用 Visual Studio 安装程序重新安装或修复 Visual Studio 安装。