如何启动调试会话(Visual C++、visual C# 和 Visual Basic)

本主题介绍如何针对用 Visual C++、Visual C# 或 Visual Basic 编写的 Windows 8 Windows 应用商店应用程序启动调试会话。调试应用程序涉及配置调试会话和选择启动应用程序的方式。

在本主题中

启动调试的简单方法

配置调试会话

  • 打开项目的调试属性页

  • 选择生成配置选项

  • 选择部署目标

  • 选择要使用的调试器

  • (可选)推迟启动调试会话

  • (可选)禁用网络环回

  • (可选)在开始调试时重新安装应用程序

  • (可选)禁用身份验证要求以启动远程调试器

启动调试会话

  • 启动调试 (F5)

  • 启动调试 (F5),但推迟启动应用程序

  • 在调试器中启动已安装的应用程序

  • 将调试器附加到正在运行的应用程序

    • 将应用程序设置为以调试模式运行

    • 附加调试器

启动调试的简单方法

  1. 在 Visual Studio 中打开应用程序解决方案。

  2. 选择 F5。

Visual Studio 生成并启动附有调试器的应用程序。持续执行至抵达某个断点、手动暂停执行、发生无法处理的异常或应用程序结束为止。有关更多信息,请参见快速入门:调试器导航(Xaml 和 C#)

配置调试会话

Hh781607.collapse_all(zh-cn,VS.110).gif打开项目的调试属性页

  1. 在解决方案资源管理器中,选择该项目。在快捷菜单中,选择**“属性”**。

  2. 执行此操作可打开项目的调试属性页:

    • 对于 Visual C# 和 Visual Basic 应用程序,选择**“调试”**。

      C# / VB 项目调试属性页

    • 对于 Visual C++ 应用程序,展开**“配置属性”节点,然后选择“调试”**。

      C++ Windows 应用商店应用程序调试属性页

Hh781607.collapse_all(zh-cn,VS.110).gif选择生成配置选项

  1. 从**“配置”列表中,选择“调试”“(活动)调试”**。

  2. 从**“平台”列表中选择要生成的目标平台。在大多数情况下,“任意 CPU”(Visual C++ 中的“所有平台”**)是最佳选择。

Hh781607.collapse_all(zh-cn,VS.110).gif选择部署目标

可在 Visual Studio 计算机上、本地计算机上的 Visual Studio 模拟器中或远程设备上部署和调试应用程序。

  • 对于 C# 和 Visual Basic 应用程序,从项目的**“调试”属性页上的“目标设备”**列表中选择目标。

  • 对于 C++ 应用程序,从**“调试”属性页上的“要启动的调试器”**列表中选择目标:

选择以下某个选项:

本地计算机

在本地计算机上的当前会话中调试应用程序。请参见在本地计算机上运行 Windows 应用商店应用程序

模拟器

在 Visual Studio 的 Windows 应用商店应用程序模拟器中调试应用程序。模拟器是一个桌面窗口,在该窗口中可调试本地计算机上未提供的设备功能,如触摸手势和设备旋转。请参见在模拟器中运行 Windows 应用商店应用程序

远程计算机

在通过 Intranet 连接到本地计算机或使用以太网电缆直接连接到本地计算机的设备上调试应用程序。若要进行远程调试,必须安装 Visual Studio 远程工具,并且远程设备上必须正在运行这些工具。请参见在远程计算机上运行 Windows 应用商店应用程序

如果选择**“远程计算机”**,则按以下某种方式指定远程计算机的名称或 IP 地址:

  • 输入远程计算机的名称或 IP 地址。

    • 对于 C# 和 Visual Basic 应用程序,在**“远程计算机”**框中输入名称或 IP 地址。

    • 对于 C++ 应用程序,在**“计算机名称”**框中输入名称或 IP 地址。

  • 从**“选择远程调试器连接”**对话框中选择远程计算机。

    若要打开此对话框,请执行以下操作:

    • 对于 C# 和 Visual Basic 应用程序,选择**“查找”**。

    • 对于 C++ 应用程序,选择**“计算机名称”框中的向下箭头,然后选择“<定位...>”**。

    “选择远程调试器连接”对话框

    备注

    “选择远程调试器连接”对话框显示本地子网上的计算机以及通过以太网电缆直接连接到 Visual Studio 计算机的计算机。若要指定其他计算机,请在“计算机名称”框中输入名称。

Hh781607.collapse_all(zh-cn,VS.110).gif选择要使用的调试器

默认情况下,Visual Studio 调试 C# 和 Visual Basic 应用程序中的托管代码。

对于 C# 和 Visual Basic 应用程序,可选择同时调试应用程序中的托管和本机 C/C++ 代码。选中**“启用非托管代码调试”**复选框,在调试会话中包括本机代码。

默认情况下,Visual Studio 调试 C++ 应用程序中的本机代码。

对于 C++ 应用程序,可选择调试应用程序组件中特定类型的代码而不调试本机代码或也调试本机代码。在应用程序项目的**“调试”属性页上“调试器类型”**列表中指定要调试的代码。

从**“调试器类型”**列表中选择以下这些调试器之一:

仅限脚本

调试应用程序中的 JavaScript 代码。忽略托管代码和本机代码。

仅限本机

调试应用程序中的本机 C/C++ 代码。忽略托管代码和 JavaScript 代码。

仅限托管

调试应用程序中的托管代码。忽略 JavaScript 代码和本机 C/C++ 代码。

混合(托管和本机)

调试应用程序中的本机 C/C++ 代码和托管代码。忽略 JavaScript 代码。

仅限 GPU

调试在离散图形卡上的图形处理单元 (GPU) 中运行本机 C++ 代码。

Hh781607.collapse_all(zh-cn,VS.110).gif(可选)推迟启动调试会话

默认情况下,启动调试后,Visual Studio 将立即启动应用程序。也可启动调试会话但推迟启动应用程序。选择此选项后,从“开始”屏幕或由激活协定启动应用程序时或者其他进程或方法启动应用程序时,将在调试器中启动应用程序。如果要在应用程序未运行时调试后台任务,则还需延迟应用程序的启动。

若要推迟启动应用程序,可:

  • 对于 Visual C# 和 Visual Basic 应用程序,在**“调试”属性页上选中“不启动,但在启动时调试代码”**。

  • 对于 Visual C++ 应用程序,从**“调试”属性页上的“启动应用程序”列表中选择“是”**。

Hh781607.collapse_all(zh-cn,VS.110).gif(可选)禁用网络环回

为安全起见,不允许以标准方式安装的 Windows 应用商店应用程序对装有它的设备进行网络调用。默认情况下,Visual Studio 部署功能为所部署的应用程序创建此规则的例外。通过此例外,在一台计算机上即可测试通信过程。向 Window 应用商店提交应用程序之前,应在没有例外的情况下测试应用程序。

若要移除网络环回例外,请执行以下操作:

  • 对于 Visual C# 和 Visual Basic 应用程序,清除**“调试”属性页上的“允许网络环回”**复选框。

  • 对于 Visual C++ 应用程序,从**“调试”属性页上的“允许网络环回”列表中选择“否”**。

Hh781607.collapse_all(zh-cn,VS.110).gif(可选)在开始调试时重新安装应用程序

若要诊断 Visual C# 或 Visual Basic 应用程序的安装和初始配置问题,请选择**“调试”属性页上的“卸载并重新安装我的程序包”**以在启动调试时重新创建原始安装。此选项对于 Visual C++ 项目不可用。

Hh781607.collapse_all(zh-cn,VS.110).gif(可选)禁用身份验证要求以启动远程调试器

默认情况下,必须提供凭据才能运行远程调试器。

安全说明安全说明

可以选择在无身份验证模式下运行远程调试器,但强烈建议不要使用此模式。在此模式下运行时,缺乏网络安全措施。只有在确认网络不会遇到恶意通信的情况下,才能选择无身份验证模式。

若有移除身份验证要求,请执行以下操作:

  1. 对于 Visual C# 和 Visual Basic 应用程序,清除**“调试”属性页上的“使用身份验证”**复选框。

  2. 对于 Visual C++ 应用程序,从**“调试”属性页上的“要求身份验证”列表中选择“否”**。

启动调试会话

Hh781607.collapse_all(zh-cn,VS.110).gif启动调试 (F5)

在**“调试”菜单上选择“启动调试”**(键盘:F5)时,Visual Studio 启动附带调试器的应用程序。持续执行至抵达某个断点、手动暂停执行、发生异常或应用程序结束为止。

Hh781607.collapse_all(zh-cn,VS.110).gif启动调试 (F5),但推迟启动应用程序

您可以将应用程序设置为在调试模式中运行,但通过调试器之外的方法启动应用程序。例如,您可能需要调试从“开始”菜单进行的应用程序启动,或在不启动应用程序的情况下调试应用程序中的后台进程。若要延迟应用程序启动,请执行下列操作:

  • 在应用程序的**“调试”属性页上(Visual C++ 中的“调试”**)

    • 对于 Visual C# 和 Visual Basic 应用程序,选中**“不启动,但启动时调试代码”**。

    • 对于 Visual C++ 应用程序,从**“启动应用程序”列表中选择“是”**。

  • 在**“调试”菜单上,选择“启动调试”**(键盘:F5)。

  • 从“开始”菜单、执行协定或由其他过程启动应用程序。

随后应用程序在调试模式下启动。持续执行至抵达某个断点、手动暂停执行、发生无法处理的异常或应用程序结束为止。

.有关调试后台任务的更多信息,请参见如何在 Windows 应用商店应用程序中触发挂起、继续和后台事件

Hh781607.collapse_all(zh-cn,VS.110).gif在调试器中启动已安装的应用程序

在使用 F5 启动调试时,Visual Studio 会生成并部署应用程序,将应用程序设置为在调试模式中运行,然后启动应用程序。若要启动设备上已安装的应用程序,请使用“调试安装的应用程序包”对话框。在需要调试已从 Windows 应用商店安装的应用程序时,或在具有应用程序的源文件但没有针对应用程序的 Visual Studio 项目时,此过程非常有用。例如,您的自定义生成系统可能不使用 Visual Studio 项目或解决方案。

应用程序可安装在本地设备上,也可安装在远程设备上。您可以立即启动应用程序,或将应用程序设置为当其通过其他进程或方法(如从“开始”菜单或通过激活协定)启动时在调试器中运行,也可以将应用程序设置为当需要在未启动应用程序的情况下调试后台进程时在调试模式中运行。有关更多信息,请参见如何在 Windows 应用商店应用程序中触发挂起、继续和后台事件

若要将已安装的应用程序设置为在调试模式中运行,请执行下列操作:

备注

在您启动此过程时,应用程序不得运行。

  1. 在**“调试”菜单上,选择“调试安装的应用程序包”**

  2. 请从列表中选择下列选项之一:

    本地计算机

    在本地计算机上的当前会话中调试应用程序。请参见在本地计算机上运行 Windows 应用商店应用程序

    模拟器

    在 Visual Studio 的 Windows 应用商店应用程序模拟器中调试应用程序。模拟器是一个桌面窗口,在该窗口中可调试本地计算机上未提供的设备功能,如触摸手势和设备旋转。请参见在模拟器中运行 Windows 应用商店应用程序

    远程计算机

    在通过 Intranet 连接到本地计算机或使用以太网电缆直接连接到本地计算机的设备上调试应用程序。若要进行远程调试,必须安装 Visual Studio 远程工具,并且远程设备上必须正在运行这些工具。请参见在远程计算机上运行 Windows 应用商店应用程序

  3. 从**“安装的应用程序包”**列表中选择应用程序。

  4. 从**“调试此代码类型”**列表中选择要使用的调试引擎。

  5. (可选)。选择**“不启动,但在启动时调试代码”**以在通过其他某种方法启动应用程序时调试应用程序或调试后台进程。

在单击**“启动”**时,应用程序将启动或设置为在调试模式中运行。

Hh781607.collapse_all(zh-cn,VS.110).gif将调试器附加到正在运行的应用程序

若要将调试器附加到 Windows 应用商店应用程序,必须使用可调式包管理器将应用程序设置为以调试模式运行。可调式包管理器与 Visual Studio 远程工具一并安装。

当需要调试已安装的应用程序(如从 Windows 应用商店安装的应用程序)时,将调试器附加到应用程序很有用。在拥有应用程序的源文件,但没有应用程序的 Visual Studio 项目时,必须进行附加。例如,您的自定义生成系统可能不使用 Visual Studio 项目或解决方案。

将调试器附加到应用程序需要执行以下这些步骤:

  1. 将应用程序设置为以调试模式运行。必须在应用程序未运行时执行此操作。

  2. 启动该应用程序。可从“开始”屏幕、执行协定或通过某些其他方法启动该应用程序。

  3. 将调试器附加到正在运行的应用程序。

Hh781607.collapse_all(zh-cn,VS.110).gif将应用程序设置为以调试模式运行

  1. 在装有该应用程序的设备上安装 Visual Studio 远程工具。请参见安装远程工具

  2. 在“开始”屏幕上,搜索 Debuggable Package Manager,然后启动它。

    随后显示 PowerShell 窗口,该窗口针对 AppxDebug cmdlet 进行了正确的配置。

  3. 若要能够调试应用程序,必须指定该应用程序的 PackageFullName 标识符。若要查看包含 PackageFullName 的所有应用程序的列表,请在 PowerShell 提示符下键入 Get-AppxPackage。

  4. 在 PowerShell 提示符下,输入 Enable-AppxDebug PackageFullName,其中 PackageFullName 是应用程序的 PackageFullName 标识符。

Hh781607.collapse_all(zh-cn,VS.110).gif附加调试器

若要附加调试器,请执行以下操作:

  1. 在**“调试”菜单上,选择“附加到进程”**。

    随后将显示**“附加到进程”**对话框。

  2. 若要附加到远程设备上的应用程序,请在**“限定符”**框中指定该远程设备。您可以:

    • 在**“限定符”**框中输入名称。

    • 选择**“限定符”**框中的下拉箭头,然后从以前已附加到的设备的列表中选择该设备。

    • 选择**“查找”**,从本地子网上设备的列表中选择该设备。

  3. 在**“附加到”**框中指定要调试的代码类型。

    选择**“选择”**,然后执行下列操作之一:

    • 选中**“自动确定要调试的代码类型”**

    • 选中**“调试以下代码类型”**,然后从列表中选择一个或多个类型。

  4. 在**“可用进程”**列表中,选择应用程序进程。

  5. 选择**“附加”**。

Visual Studio 将调试器附加到该进程。持续执行至抵达某个断点、手动暂停执行、发生无法处理的异常或应用程序结束为止。

请参见

概念

调试 Windows 应用商店应用程序

快速入门:调试器导航(Xaml 和 C#)