适用范围: yes Visual Studio no Visual Studio for Mac no Visual Studio Code

若要设置 Visual Studio 调试器选项,选择“工具”>“选项”,在“调试”中选中或取消选中“常规”选项旁边的选择框 。 可以通过“工具” > “导入和导出设置”>“重置所有设置”恢复所有默认设置 。 若要重置设置的子集,在做出要测试的更改之前,使用“导入和导出设置向导”保存设置,然后在以后导入保存的设置。

可以设置以下“常规”选项:

在删除所有断点之前询问 :在完成“删除所有断点”命令前需要进行确认。

当一个进程中断时,中断所有进程 : 发生一个中断时,同时中断调试器连接到的所有进程。

当异常跨越 AppDomain 或托管/本机边界时中断 :在托管或混合模式调试中,如果满足以下条件,公共语言运行时可能会捕获跨越应用程序域边界或托管/本机边界的异常:

  • 当本机代码使用 COM 互操作调用托管代码且托管代码引发异常。 请参阅 COM 互操作介绍

  • 应用程序域 1 中运行的托管代码调用应用程序域 2 中的托管代码,且应用程序域 2 中的代码引发异常。 请参阅 应用程序域编程

  • 代码通过使用反射调用一个函数时且该函数引发异常。 请参阅 反射

    在 2 和 3 的情况下,异常有时由 mscorlib 中的托管代码而非由公共语言运行时捕获。 此选项不影响在 mscorlib 捕获到异常时中断。

    启用地址级调试 :启用高级功能在地址级上进行调试(“反汇编”窗口、“注册”窗口和地址断点) 。

  • 如果源不可用,则显示反汇编:调试的代码来源不可用时,自动显示“反汇编”窗口。
  • 启用断点筛选器 :允许你在断点上设置筛选器,使其仅影响特定的进程、线程或计算机。

    使用新的异常帮助器 :启用替换了异常助手的异常帮助程序。 (从 Visual Studio 2017 开始支持异常处理程序)

    对于托管代码,此选项以前称为“启用异常助手”。

    启用“仅我的代码” :调试器仅显示和单步执行用户代码(“我的代码”),而忽略系统代码和其他经过优化或没有调试符号的代码。

  • 启动时若没有用户代码则发出警告(仅限托管):如果在调试时启用“仅我的代码”,此选项会在没有用户代码(“我的代码”)的情况下发出警告。
  • 启用 .NET Framework 源代码单步执行 :允许调试器单步执行 .NET Framework 源代码。 启用此选项会自动禁用“仅我的代码”。 .NET Framework 符号将下载到缓存位置。 使用“选项”对话框>“调试类别”>“符号”页面可更改缓存位置 。

    单步执行属性和运算符(仅限托管) :防止调试器单步执行托管代码中的属性和运算符。

    启用属性求值和其他隐式函数调用 :在变量窗口和“快速监视”对话框中打开属性的自动求值和隐式函数调用。

  • 在变量窗口中对对象调用字符串转换函数(仅限 C# 和 JavaScript) :在变量窗口中计算对象时,执行隐式字符串转换调用。 结果将显示为字符串而不是类型名。 仅在 C# 代码中进行调试时适用。 此设置可以由 DebuggerDisplay 特性替代(请参阅 使用 DebuggerDisplay 特性 )。
  • 启用源服务器支持 :指示 Visual Studio 调试器从实现 SrcSrv ( srcsrv.dll ) 协议的源服务器中获取源文件。 Team Foundation Server 和 Windows 的调试工具是实现协议的两个源服务器。 有关 SrcSrv 设置的详细信息,请参阅 SrcSrv 文档。 此外,请参阅 指定符号 (.pdb) 和源文件

    由于读取 .pdb 文件可在文件中执行任意代码,因此请确保你信任该服务器。

  • 将源服务器诊断消息打印到“输出”窗口:如果启用源服务器支持,此设置会打开诊断显示。

  • 允许源服务器中的部分信任程序集(仅限托管):若源服务器支持已启用,此设置将替代不检索部分信任程序集的源这一默认行为。

  • 始终运行不受信任的源服务器命令并且不再提示:若源服务器支持已启用,此设置将替代运行不受信任的命令时进行提示这一默认行为。

    启用源链接支持 :告知 Visual Studio 调试器下载包含源链接信息的 .pdb文件的源文件。 有关源链接的详细信息,请参阅 源链接规范

    由于源链接将使用 http 或 https 下载文件,因此请确保你信任该 .pdb 文件。

  • 对于所有源链接请求,回退到 Git 凭据管理器身份验证:若源链接支持已启用且源链接请求未通过身份验证,则 Visual Studio 调用 Git 凭据管理器。
  • 突出显示断点和当前语句所在的整个源行(仅限 C++):调试器突出显示断点或当前语句时,会突出显示整个行。

    要求源文件与原始版本完全匹配 :指示调试器验证源文件是否与用于构建待调试的可执行文件的源代码版本匹配。 若版本不匹配,系统会提示你查找匹配的源。 若找不到匹配的源,调试过程中将不会显示源代码。

    将所有“输出”窗口文本重定向到“即时”窗口 :将通常显示在“输出”窗口中的所有调试器消息发送到“即时”窗口。

    在变量窗口中显示对象的原始结构 :关闭所有对象结构视图自定义。 有关视图自定义的详细信息,请参阅 创建托管对象的自定义视图

    在模块加载时取消 JIT 优化(仅限托管) :在附加调试器的情况下,加载模块并编译 JIT 后,禁用托管代码的 JIT 优化。 禁用优化可能更易于调试某些问题,尽管这会降低性能。 如果正在使用“仅我的代码”,则取消 JIT 优化会导致非用户代码显示为用户代码(“我的代码”)。 有关详细信息,请参阅 JIT 优化和调试

    启用适用于 ASP.NET 的 JavaScript 调试(Chrome、Microsoft Edge 和 IE):为 ASP.NET 应用启用脚本调试。 第一次在 Chrome 中使用时,可能需要登录到浏览器来启用已安装的 Chrome 扩展。 禁用此选项可恢复为旧行为。

    启用使用多目标 JavaScript 调试器来调试适用目标中的 JavaScript(需要调试重启)允许同时连接到浏览器和后端,使你能够在编辑器中直接调试在客户端和服务器中运行的代码。

    加载 dll 导出(限本机) :加载 DLL 导出表。 处理 Windows 消息、Windows 过程 (WindowProc)、COM 对象、封送或不具有其符号的任何 DLL 时,DLL 导出表中的符号信息将很有用。 读取 DLL 导出信息会占用一些系统开销。 因此,默认情况下此功能被禁用。

    若要查看 DLL 导出表中的可用符号,请使用 dumpbin /exports 。 符号可用于任何 32 位系统 DLL。 从 dumpbin /exports 输出中,可以查看到精确的函数名,包括非字母数字字符。 这对于在函数上设置断点很有用。 DLL 导出表中的函数名在调试器的其他位置似乎被截断了。 调用将按调用顺序列出,当前函数(嵌套最深的函数)位于顶端。 有关详细信息,请参阅 dumpbin /exports

    自下而上显示并行堆栈关系图 :控制堆栈在“并行堆栈”窗口中的显示方向。

    如果写入的数据未更改值,则忽略 GPU 内存访问异常 :在调试时如果数据未更改,将忽略检测到的争用条件。 有关详细信息,请参阅 调试 GPU 代码

    使用托管兼容模式 :将默认调试引擎替换为旧版本,以支持以下方案:

  • 使用 C#、Visual Basic 或 F# 以外的 .NET 语言,该语言提供自己的表达式计算器(包括 C + + CLI)。

  • 想要在混合模式调试过程中为 C++ 项目启用“编辑并继续”。

    选择托管兼容模式会禁用仅可在默认调试引擎中实现的一些功能。 旧版调试引擎已在 Visual Studio 2012 中进行了替换。

    使用自定义调试器可视化工具时,针对可能不安全的进程发出警告(仅限托管): 如果使用自定义调试器可视化工具在调试的进程中运行代码,Visual Studio 会发出警告,因为该调试器可能运行不安全的代码。

    启用 Windows 调试堆分配器(仅限本地) :启用 Windows 调试堆以改进堆诊断。 启用此选项会影响调试性能。

    启用 XAML 的 UI 调试工具 :当开始调试 (F5) 支持的项目类型时,会显示实时可视化树和实时属性资源管理器窗口。 有关详细信息,请参阅 调试时检查 XAML 属性

  • 预览实时可视化树中的所选元素:选定了其上下文的 XAML 元素在“实时可视化树”窗口中也会被选中。

  • 在应用程序中显示运行时工具 :如果选中一个 XAML 元素的上下文,同时会在“实时可视化树”窗口中选中该元素。 Visual Studio 2015 Update 2 中引入了此选项。

  • 启用 XAML 热重载:允许你在应用运行时将 XAML 热重载功能与 XAML 代码一起使用。 (此功能以前称为“XAML 编辑并继续”)

  • 启用“仅我的 XAML”:从 Visual Studio 2019 版本 16.4 开始,“实时可视化树”在默认情况下只显示归类为用户代码的 XAML。 如果禁用此选项,则会在工具中显示所有生成的 XAML 代码。

  • 选择元素时关闭选择模式 从 Visual Studio 2019 版本 16.4 开始,在选择元素时,应用内工具栏元素选择器按钮(“启用选定内容”)会关闭。 如果禁用此选项,则元素选择将一直保持打开状态,直到再次单击应用内程序工具栏按钮。

  • 在保存文档时应用 XAML 热重载 从 Visual Studio 2019 版本 16.6 开始,在保存文档时会应用 XAML 热重载。

    调试时启用诊断工具 :调试时显示“诊断工具”窗口。

    在调试过程中显示运行时间 PerfTip :在进行调试时,代码窗口会显示给定方法调用的运行时间。

    启用“编辑并继续” :在进行调试时,启用“编辑并继续”功能。

  • 启用本机“编辑并继续” :在调试本机 C++ 代码时,你可以使用“编辑并继续”功能。 有关详细信息,请参阅 编辑并继续 (C++)

  • 继续执行进程时应用更改(仅限本机) : 从中断状态中恢复并继续执行进程时,Visual Studio 会自动编译并应用任何待执行的代码更改。 可选择使用“调试”菜单下的“应用代码更改”项来应用更改(如果尚未选择) 。

  • 针对旧代码发出警告(仅限本机):收到关于旧代码的警告。

    调试时在编辑器中显示“运行以单击”按钮 :选中此选项后,在调试时,将会显示 运行以单击 按钮。

    调试停止时自动关闭控制台 :告知 Visual Studio 在调试会话结束时关闭控制台。

    启用快速表达式计算(仅限托管):允许调试器通过模拟简单属性和方法的执行来尝试更快速地进行计算。

    在外部进程中加载调试符号(仅限本机)在调试时启用此 内存优化

    调试器中断时,将 Visual Studio 置于前台 在调试器中暂停时,将 Visual Studio 切换到前台。

    保持展开的数据提示保持打开状态,直到单击:选择此选项后,展开的数据提示将保持展开状态,直到单击它。

    早期版本的 Visual Studio 中可用的选项

    如果使用早期版本的 Visual Studio,则可能会出现一些其他选项。

    启动适用于 UWP JavaScript 应用(实验性)的 Edge 开发人员工具 : 在 Microsoft Edge 中启用适用于 UWP JavaScript 应用的开发人员工具。

    启用适用于ASP.NET应用的旧版 Chrome JavaScript 调试器 :启用适用于 ASP.NET 应用的旧版 Chrome JavaScript 脚本调试器。 第一次在 Chrome 中使用时,可能需要登录到浏览器来启用已安装的 Chrome 扩展。

    启用异常助手 :对于托管代码,启用异常助手。 从 Visual Studio 2017 开始,异常帮助程序替换了异常助手。

    在未经处理的异常上展开调用堆栈 :导致“调用堆栈”窗口将调用堆栈回滚到未经处理的异常发生之前的时间点。

    以管理员身份运行 Visual Studio 时,使用实验性方法启动 Chrome JavaScript 调试: 告知 Visual Studio 在 JavaScript 调试期间尝试新方式来启动 Chrome。

    启动时若无符号则发出警告(仅限本机) :当调试器没有所调试程序的符号信息时,显示一个警告对话框。

    如果启动时禁用了脚本调试,发出警告 :如果在启动调试器时禁用了脚本调试,则会显示警告对话框。

    使用托管兼容模式:选择此选项后,调试器将使用 Visual Studio 2010 托管调试器,这是调试 C++/CLI 代码时所必需的。

    使用本机兼容性模式 :选中此选项后,调试器使用 Visual Studio 2010 本机调试器而不是新的本机调试器。

  • 如果正在调试 .NET C++ 代码,请使用此选项,因为新的调试引擎不支持计算 .NET C++ 表达式。 但是,启用本机兼容模式会禁用依赖于当前调试器实现来操作的许多功能。 例如,旧引擎缺少许多用于内置类型(如 Visual Studio 2015 项目中的 std::string )的可视化工具。 为获得最佳调试体验,在这些应用场景中请使用 Visual Studio 2013 项目。
  • 在 Visual Studio 中进行调试
  • 初探调试器
  •