如何使用 Microsoft C++ 工具集或文档报告问题

如果发现 Microsoft C++ 编译器 (MSVC)、链接器或其他工具和库的问题,请告诉我们。 文档中存在问题时,我们也想要了解。

如何报告 C++ 工具集问题

告知我们问题的最佳方式是向我们发送有关已发现的问题描述的报告。 它应包含有关如何生成程序的所有详细信息。 而且它应包括“重现” ,即我们可在我们自己的计算机上重现该问题的完整测试用例。 此信息可以让我们快速验证是否是代码中存在该问题,而不是你本地环境的问题。 它可帮助我们确定是否会影响编译器的其他版本,并诊断其原因。

以下部分将介绍好的报告所包含的内容。 我们将描述如何生成所发现问题类型的重现,以及如何将报告发送给产品团队。 无论对我们,还是对和你一样的其他开发者而言,你的报告都十分重要。 谢谢你帮助我们改进 Microsoft C++!

如何准备报告

最好创建高质量报告,因为如果缺少完整信息,很难重现你发现的问题。 报告的质量越高,我们重新创建和诊断问题的效率就越高。

报告中应至少包括:

  • 正在使用的工具集的完整版本信息。

  • 用于生成代码的完整 cl.exe 命令行。

  • 对所发现问题的详细描述。

  • 重现:简单完整的自包含源代码示例,用于演示问题。

继续阅读,详细了解我们需要的特定信息,在何处可以找到它们,以及如何创建高质量重现。

工具集版本

我们需要完整的版本信息和导致此问题的工具集的目标体系结构。 这样我们就可以针对我们的计算机的相同工具集测试你的重现。 如果我们可以重现此问题,我们还可以将此信息作为起点,调查哪些版本的工具集存在同样的问题。

报告你正在使用的编译器的完整版本

  1. 打开与用于生成项目的 Visual Studio 版本和配置体系结构匹配的“开发人员命令提示” 。 例如,如果在 x64 上使用 Visual Studio 2017 生成面向 x64 的项目,请选择“适用于 VS 2017 的 x64 本机工具命令提示” 。 有关详细信息,请参阅开发人员命令提示快捷方式

  2. 在“开发人员命令提示”控制台窗口中,输入命令 cl/Bv 。

输出应类似于:

C:\Users\username\Source>cl /Bv
Microsoft (R) C/C++ Optimizing Compiler Version 19.14.26428.1 for x86
Copyright (C) Microsoft Corporation.  All rights reserved.

Compiler Passes:
 C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Tools\MSVC\14.14.26428\bin\HostX86\x86\cl.exe:        Version 19.14.26428.1
 C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Tools\MSVC\14.14.26428\bin\HostX86\x86\c1.dll:        Version 19.14.26428.1
 C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Tools\MSVC\14.14.26428\bin\HostX86\x86\c1xx.dll:      Version 19.14.26428.1
 C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Tools\MSVC\14.14.26428\bin\HostX86\x86\c2.dll:        Version 19.14.26428.1
 C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Tools\MSVC\14.14.26428\bin\HostX86\x86\link.exe:      Version 14.14.26428.1
 C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Tools\MSVC\14.14.26428\bin\HostX86\x86\mspdb140.dll:  Version 14.14.26428.1
 C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Tools\MSVC\14.14.26428\bin\HostX86\x86\1033\clui.dll: Version 19.14.26428.1

cl : Command line error D8003 : missing source filename

将整个输出复制并粘贴到报告。

命令行

我们需要准确的命令行、cl.exe 及其所有参数,用于生成代码。 这样我们就可以在我们的计算机上以完全相同的方式生成它。 这一点很重要,因为你所发现的问题可能仅在使用某一特定参数或参数组合生成时才存在。

此信息位于遇到问题后立即出现的生成日志中,建议在该位置查找。 这可确保命令行包含完全相同的参数,从而有可能帮助解决问题。

报告命令行的内容

  1. 找到并打开 CL.command.1.tlog 文件。 默认情况下,此文件位于“文档”文件夹下的 \Visual Studio version \Projects\SolutionName\ProjectName\Configuration\ProjectName.tlog\CL.command.1.tlog,或“用户”文件夹下的 \Source\Repos\SolutionName\ProjectName\Configuration\ProjectName.tlog\CL.command.1.tlog 中。 如果使用其他生成系统,或更改了项目的默认位置,则该文件可能位于其他位置。

    可在此文件中找到源代码文件的名称,其后是用于编译它们的命令行参数(每个分占一行)。

  2. 找到包含出现问题的源代码文件名称的行。 其下方的行包含相应的 cl.exe 命令参数。

将整个命令行复制并粘贴到报告。

问题说明

我们需要对所发现问题的详细描述。 这样我们就可以确认在我们的计算机上看到相同的效果。 让我们了解你尝试完成的内容以及你预期发生的内容有时也非常有用。

好的描述会提供工具集给出的确切错误消息,或者看到的确切运行时行为 。 我们需要此信息来验证是否已正确重现问题。 提供所有编译器输出,而不仅仅是最后一个错误消息 。 我们需要查看与所报告问题相关的所有信息。 如果可以使用命令行编译器来复制问题,该编译器输出是首选。 IDE 和其他生成系统可能会筛选你看到的错误消息,或者仅捕获一条错误消息的第一行。

如果问题是编译器接受无效的代码并且未生成诊断,请在报告中包含此内容。

若要报告运行时行为问题,请提供该程序输出内容的原样副本,和你想要看到的内容 。 理想情况下,它嵌入在输出语句本身中,例如 printf("This should be 5: %d\n", actual_result);。 如果程序崩溃或挂起,也请提到这一点。

添加任何其他可能有助于我们诊断你发现的问题的详细信息,例如,你可能已发现的任何变通方法。 请尝试不在报表的其他部分出现重复信息。

重现

重现 是一个完整的自包含源代码示例。 它以可重现的方式演示了你发现的问题,并由此得名。 我们需要重现来在自己的计算机上重现错误。 代码本身应足以创建一个可编译和运行的基本可执行文件。 或者,其将编译和运行(如果不是针对你发现的问题)。 重现不是代码片段。 它应具有完整的函数和类,并包含所有必要 #include 指令,即使对于标准标头也是如此。

高质量重现的标准

高质量重现的标准为:

  • 最小的。 重现应尽可能最小,但仍能准确演示所发现的问题。 重现无需复杂或真实。 它们只需显示符合标准或记录的编译器实现的代码。 对于缺失的诊断,你的重现应显示不符合的代码。 重现应简明扼要,最好只包含刚好足够演示问题的代码。 如果删除或简化某些代码也能保持符合性,并且不改变问题,请进行删除或简化。 不需要提供有效代码的反例。

  • 自包含。 重现应避免不需要的依赖项。 如果无需第三方库就可重现,请直接重现。 如果无需任何库代码,只需简单的输出语句(例如,puts("this shouldn't compile");std::cout << value;printf("%d\n", value);)即可重现此问题,请使用简单的输出语句。 最理想的情况是,示例可以压缩为单个源代码文件,而不引用任何用户标头。 尽可能减少我们需要考虑的有利于解决问题的代码量,这对我们而言极为有用。

  • 针对最新版本的编译器。 重现应尽可能使用最新版本的工具集的最近更新。 或者,使用下一个更新或下一个主要版本的最新预发布版本。 在旧版本工具集中可能会发现的问题很可能已在新版本中得到修复。 只有在特殊情况下,才会将修复向后移植到旧版本。

  • 针对其他编译器进行检查(如果相关)。 在可能的情况下,涉及可移植 C++ 代码的重现,应在其他编译器中验证行为。 C++ 标准最终确定程序的正确性,没有编译器是完美的。 但是,如果 Clang 和 GCC 接受了代码但没有诊断,而 MSVC 未接受,则你可能已经在我们的编译器中发现了一个 bug。 (其他可能性包括 Unix 和 Windows 行为的差异,或者 C++ 标准实现的级别不同等。)如果所有编译器都拒绝你的代码,则可能是代码不正确。 查看不同的错误消息可能有助于自行诊断问题。

    你可以在 ISO C++ 网站上的在线C++编译器中找到在线编译器列表,或查看 GitHub 上的在线C ++ 编译器列表,针对这些编译器来测试代码。 一些具体示例包括 WandboxCompiler Explorer

    注意

    在线编译器网站不隶属于 Microsoft。 许多在线编译器网站作为个人项目运行。 当你读取此代码时,其中某些网站可能不可用,但搜索应该能找到可以使用的其他网站。

编译器、链接器和库中的问题往往以特定的方式显示。 所发现问题的类型决定了应在报告中添加的重现类型。 如果无法正确重新,我们将无法进行调查。 你可能会看到的一些问题如下。 我们随附了有关如何生成应用于报告每种问题的重现类型的说明。

前端(分析程序)故障

前端故障发生在编译器的分析阶段。 通常情况下,编译器将发出致命错误 C1001,并引用发生错误的源代码文件和行号。 它经常提到一个名为 msc1.cpp 的文件,但你可以忽略此详细信息。

对于这种类型的故障,请提供预处理过的重现

下面是此种故障类型的示例编译器输出:

SandBoxHost.cpp
d:\o\dev\search\foundation\common\tools\sandbox\managed\managed.h(929):
        fatal error C1001: An internal error has occurred in the compiler.
(compiler file 'msc1.cpp', line 1369)
To work around this problem, try simplifying or changing the program near the
        locations listed above.
Please choose the Technical Support command on the Visual C++
Help menu, or open the Technical Support help file for more information
d:\o\dev\search\foundation\common\tools\sandbox\managed\managed.h(929):
        note: This diagnostic occurred in the compiler generated function
        'void Microsoft::Ceres::Common::Tools::Sandbox::SandBoxedProcess::Dispose(bool)'
Internal Compiler Error in d:\o\dev\otools\bin\x64\cl.exe.  You will be prompted
        to send an error report to Microsoft later.
INTERNAL COMPILER ERROR in 'd:\o\dev\otools\bin\x64\cl.exe'
    Please choose the Technical Support command on the Visual C++
    Help menu, or open the Technical Support help file for more information

后端(代码生成)故障

后端故障发生在编译器的代码生成阶段。 通常情况下,编译器将发出致命错误 C1001,且可能不会引用与错误相关的源代码文件和行号。 它通常会提及文件 compiler\utc\src\p2\main.c,但你可以忽略此详细信息。

对于这种类型的故障,如果使用通过 cl.exe 的 /GL 命令行参数启用的链接时间代码生成 (LTCG),请提供链接重现 。 如果未使用,请转为提供预处理过的重现

下面是后端故障的示例编译器输出,其中未使用 LTCG。 如果编译器输出与以下内容类似,请提供预处理过的重现

repro.cpp
\\officefile\public\tadg\vc14\comperror\repro.cpp(13) : fatal error C1001:
        An internal error has occurred in the compiler.
(compiler file 'f:\dd\vctools\compiler\utc\src\p2\main.c', line 230)
To work around this problem, try simplifying or changing the program near the
        locations listed above.
Please choose the Technical Support command on the Visual C++
Help menu, or open the Technical Support help file for more information
INTERNAL COMPILER ERROR in
        'C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\BIN\cl.exe'
    Please choose the Technical Support command on the Visual C++
    Help menu, or open the Technical Support help file for more information

如果以内部编译器错误开头的行提及 link.exe,而不是 cl.exe,则已启用 LTCG。 对于此情况,请提供链接重现。 当不清楚是否从编译器错误消息启用了 LTCG 时,请检查命令行参数。 在 /GL 命令行参数的上一步中,从生成日志复制这些信息。

链接器故障

链接器故障发生在链接阶段,在编译器已运行之后。 通常情况下,链接器将发出链接器工具错误 LNK1000

注意

如果输出提及 C1001 或涉及链接时间代码生成,请改为参阅后端(代码生成)故障

对于这种类型的故障,请提供链接重现

下面是此种故障类型的示例编译器输出:

z:\foo.obj : error LNK1000: Internal error during IMAGE::Pass2

  Version 14.00.22816.0

  ExceptionCode            = C0000005
  ExceptionFlags           = 00000000
  ExceptionAddress         = 00007FF73C9ED0E6 (00007FF73C9E0000)
        "z:\tools\bin\x64\link.exe"
  NumberParameters         = 00000002
  ExceptionInformation[ 0] = 0000000000000000
  ExceptionInformation[ 1] = FFFFFFFFFFFFFFFF

CONTEXT:

  Rax    = 0000000000000400  R8     = 0000000000000000
  Rbx    = 000000655DF82580  R9     = 00007FF840D2E490
  Rcx    = 005C006B006F006F  R10    = 000000655F97E690
  Rdx    = 000000655F97E270  R11    = 0000000000000400
  Rsp    = 000000655F97E248  R12    = 0000000000000000
  Rbp    = 000000655F97EFB0  E13    = 0000000000000000
  Rsi    = 000000655DF82580  R14    = 000000655F97F390
  Rdi    = 0000000000000000  R15    = 0000000000000000
  Rip    = 00007FF73C9ED0E6  EFlags = 0000000000010206
  SegCs  = 0000000000000033  SegDs  = 000000000000002B
  SegSs  = 000000000000002B  SegEs  = 000000000000002B
  SegFs  = 0000000000000053  SegGs  = 000000000000002B
  Dr0    = 0000000000000000  Dr3    = 0000000000000000
  Dr1    = 0000000000000000  Dr6    = 0000000000000000
  Dr2    = 0000000000000000  Dr7    = 0000000000000000

如果启用了增量链接,且仅在进行成功地初始链接之后才发生故障(也就是说,仅在第一个完整链接之后才发生,随后的增量链接都基于该完整链接),请提供对象 (.obj) 和库 (.lib) 文件的副本,它们对应于初始链接完成后经过修改的源文件。

错误代码生成

生成错误代码的情况很少见。 它会在当编译器错误地生成会导致应用程序在运行时崩溃的不正确的代码时发生。 相反,它应生成正确的代码,或在编译时检测到问题。 如果你认为所发现的问题会导致错误代码生成,请将报告同样视为后端(代码生成)故障

对于这种类型的故障,如果使用 cl.exe 的 /GL 命令行参数,请提供链接重现。 如果未使用,请提供预处理过的重现

如何生成重现

高质量重现对于帮助我们跟踪问题的根源至关重要。 在针对特定类型的重现执行以下任何步骤之前,请尝试尽可能减少用于说明问题的代码。 尝试消除或最小化依赖项、必需的标头和库。 限制编译器选项和可能使用的预处理器定义。

以下是生成用于报告不同类型问题的各种重现的说明。

预处理过的重现

预处理过的重现 是单个源文件,用于说明问题。 它是从 C 预处理器的输出生成的。 若要创建一个预处理过的重现,请在原始重现源文件上使用 /P 编译器选项。 此选项内联包含的标头以删除其他源文件和标头文件上的依赖项。 此选项还可解析宏、#ifdef 条件语句和其他可能依赖于你的本地环境的预处理器命令。

注意

对于在标准库实现中可能导致 Bug 的问题,预处理过的重现可能不是很有用,因为我们经常会替换正在进行的最新实现,以确定我们是否已修复问题。 在这种情况下,请勿预处理重现,此外,如果无法将问题减少为单个源文件,请将代码打包为 .zip 文件或类似文件,或考虑使用 IDE 项目重现。 有关详细信息,请参阅其他重现

预处理源代码文件

  1. 捕获用于生成重现的命令行参数,如报告命令行的内容中所述。

  2. 打开与用于生成项目的 Visual Studio 版本和配置体系结构匹配的“开发人员命令提示” 。

  3. 转到包含重现项目的目录。

  4. 在“开发人员命令提示”控制台窗口中,输入命令 cl /P arguments filename.cpp。 有关自变量 ,请使用之前捕获的自变量列表。 filename.cpp 是重现源文件的名称。 此命令复制用于重现的命令行,但在预处理器传递后停止编译。 然后将预处理过的源代码输出到 filename.i 。

如果正在预处理 C++/CX 源代码文件,或正在使用 C++ 模块功能,则需执行一些额外步骤。 有关详细信息,请参见下方内容。

如果已生成了预处理过的文件,最好确保在你编译预处理过的文件时问题仍可重现。

确认预处理过的文件仍可重现错误

  1. 在“开发人员命令提示”控制台窗口中,输入命令 cl arguments /TP filename.i,指示 cl.exe 将预处理过的文件编译为 C++ 源文件。 此参数 与上文捕获的参数相同,但删除了任何 /D 和 /I 参数。 这是因为它们已包含在预处理过的文件中。 filename.i 是预处理过的文件的名称。

  2. 确认该问题可被重现。

最后,将预处理过的重现 filename.i 附加到报告中 。

预处理过的 C++/CX WinRT/UWP 代码重现

如果使用 C++/CX 生成可执行文件,则需执行一些额外步骤来创建和验证预处理过的重现。

预处理 C++/CX 源代码

  1. 预处理源代码文件的介绍创建一个预处理过的源代码文件。

  2. 在生成的 filename.i 文件中搜索 #using 指令 。

  3. 列出所有参考文件。 省去所有 Windows*.winmd 文件、platform.winmd 文件和 mscorlib.dll。

准备验证预处理过的文件是否仍然会出现该问题

  1. 为预处理过的文件创建一个新目录并将其复制到新目录。

  2. 将 #using 列表中的 .winmd 文件复制到新目录 。

  3. 在新目录中创建一个空 vccorlib.h 文件。

  4. 编辑预处理过的文件,删除 mscorlib.dll 的所有 #using 指令 。

  5. 编辑预处理过的文件,将所有绝对路径更改为复制的 .winmd 文件的文件名。

如上所述,确认预处理过的文件是否仍然会出现该问题。

预处理过的 C++ 模块重现

如果正在使用 C++ 编译器的模块功能,则需执行一些不同的步骤来创建和验证预处理过的重现。

预处理使用模块的源代码文件

  1. 捕获用于生成重现的命令行参数,如报告命令行的内容中所述。

  2. 打开与用于生成项目的 Visual Studio 版本和配置体系结构匹配的“开发人员命令提示” 。

  3. 转到包含重现项目的目录。

  4. 在“开发人员命令提示”控制台窗口中,输入命令 cl /P arguments filename.cpp。 此参数 与上文捕获的参数相同,filename.cpp 是使用该模块的源文件的名称。

  5. 更改为包含用于生成模块接口(.ifc 输出)的重现项目的目录。

  6. 捕获用于生成模块接口的命令行参数。

  7. 在“开发人员命令提示”控制台窗口中,输入命令 cl /P arguments modulename.ixx。 此参数 与上文捕获的参数相同,modulename.ixx 是创建模块界面的文件的名称。

如果已生成了预处理过的文件,最好确保在你使用预处理过的文件时问题仍可重现。

确认预处理过的文件仍可重现错误

  1. 在开发人员控制台窗口中,转回包含重现项目的目录。

  2. 输入上述命令 cl arguments /TP filename.i,将预处理过的文件视为 C++ 源文件进行编译

  3. 确认预处理过的文件是否仍然会出现该问题。

最后,将预处理过的重现文件(filename.i 和 modulename.i)与 .ifc 输出一起附加到报告中 。

链接重现是链接器生成的目录内容,该目录内容由 link_repro 环境变量指定,或指定为 /LINKREPRO 链接器选项的参数。 它包含共同说明链接时所出现问题的生成项目。 示例包括涉及链接时间代码生成 (LTCG) 的后端故障或链接器故障。 需要将这些生成工件用作链接器输入,以便重现问题。 通过使用此环境变量,可以轻松创建链接重现。 它可启用链接器的内置重现生成功能。

  1. 捕获用于生成重现的命令行参数,如报告命令行的内容中所述。

  2. 打开与用于生成项目的 Visual Studio 版本和配置体系结构匹配的“开发人员命令提示” 。

  3. 在开发人员命令提示控制台窗口中,转到包含重现项目的目录。

  4. 输入 mkdir linkrepro,为链接重现创建名为 linkrepro 的目录 。 可以使用不同的名称来捕获另一个链接重现。

  5. 输入命令 set link_repro=linkrepro,将 link_repro 环境变量设置为你创建的目录。 如果生成从其他目录中运行(更加复杂的项目通常如此),则转而将 link_repro 设置为链接重现目录的完整路径。

  6. 要在 Visual Studio 中生成重现项目,请在开发人员命令提示控制台窗口中输入命令 devenv 。 这可确保 link_repro 环境变量的值对 Visual Studio 可见。 要在命令行生成项目,请使用前面捕获的命令行参数来复制重现生成。

  7. 生成重现项目,并确认预期问题已发生。

  8. 如果使用了 Visual Studio 执行生成,请将其关闭。

  9. 在开发人员命令提示符控制台窗口中,输入命令 set link_repro=,清除 link_repro 环境变量。

最后,通过将整个 linkrepro 目录压缩为 .zip 文件或类似的文件来打包重现,并将其附加到报告中。

/LINKREPRO 链接器选项与 link_repro 环境变量具有同样的作用。 可以使用 /LINKREPROTARGET 选项来为生成的链接重现指定要筛选的名称。 要使用 /LINKREPROTARGET,还必须指定 /OUT 链接器选项 。

  1. 创建目录以保存链接重现。 我们将创建的完整目录路径称作 directory-path 。 如果路径包含空格,请使用双引号。

  2. 将 /LINKREPRO:directory-path 命令添加到链接器命令行 。 在 Visual Studio 中,打开项目的“属性页”对话框 。 选择“配置属性”>“链接器”>“命令行”属性页 。 在“附加选项”框中输入 /LINKREPRO:directory-path 选项 。 选择“确定”以保存更改 。

  3. 生成重现项目,并确认预期问题已发生。

最后,通过将整个 directory-path 链接重现目录压缩为 .zip 文件或类似的文件来打包重现,并将其附加到报告中 。

其他重现

如果无法将问题减少为单个源文件或预处理过的重现,且此问题无需链接重现,我们可以调查 IDE 项目。 有关如何创建高质量重现的所有指导仍适用:该代码应该是最小且自包含的。 问题应发生在最新的工具中,并且如果相关,不应出现在其他编译器中。

将重现创建为一个最小的 IDE 项目,再将整个目录结构压缩成 .zip 文件或其他相似文件,并将其附加到报告。

发送报告的方式

可通过多种方式向我们提交报告。 可使用 Visual Studio 的内置问题报告工具Visual Studio 开发者社区页面。 还可以使用此页底部的“产品反馈” 按钮。 选择取决于你是否想要使用 IDE 中的内置工具捕获屏幕快照和组织报告。 如果你不想,可以直接使用开发人员社区网站。

注意

无论以何种方式提交报告,Microsoft 都尊重你的隐私。 Microsoft 致力于遵守所有数据隐私法律和法规。 有关我们如何处理你发送给我们的数据的信息,请参阅 Microsoft 隐私声明

使用“报告问题”工具

Visual Studio 用户可使用 Visual Studio 中的“报告问题”工具报告问题,单击几下即可完成 。 它会弹出一个简单的表单,发送有关你已发现的问题的详细信息。 然后,无需离开 IDE 即可提交报告。

可在 IDE 中使用“报告问题”工具快速而轻松地报告问题 。 可以通过选择“快速启动”搜索框旁边的“发送反馈”图标从标题栏进行访问 。 或者,可以在菜单栏“帮助” >“发送反馈” >“报告问题” 上找到它。

选择报告问题时,请首先在开发者社区中搜索是否有类似的问题。 如果有人之前已报告过你的问题,可投票赞成该报告并添加其他细节评论。 如果找不到类似问题,请在“Visual Studio 反馈”对话框底部选择“报告新问题”按钮,再按照步骤报告你的问题 。

使用“Visual Studio 开发者社区”页面

还可使用“Visual Studio 开发者社区”页面轻松报告问题并查找有关 Visual Studio 以及 C++ 编译器、工具和库的解决方案。 有针对 Visual StudioVisual Studio for Mac.NETC++Azure DevOpsAzure DevOps Server 的特定开发者社区页。

社区标签下方每个页面顶部附近有一个搜索框。 可用它查找报告与你的问题类似的文章。 你可能发现你的问题已经有解决方案或相关的其他有用信息。 如果有人之前已报告过相同问题,请投票赞成该报告并进行评论,而不是创建新的问题报告。 若要评论、投票或报告新问题,可能要求你登录到你的 Visual Studio 帐户。 第一次登录时,你需要同意授予开发人员社区应用访问你的配置文件的权限。

有关 C++ 编译器、链接器及其他工具和库的相关问题,请首先搜索 C++ 开发者社区页面。 如果搜索你的问题后发现无人报告该问题,请选择搜索框附近的“报告问题”按钮。 可附上重现代码和命令行、屏幕截图、相关讨论的链接,以及你认为相关和有用的任何其他信息。

提示

初始开发者社区报告中的信息将始终公开。 如果你对此有疑问,请参阅下一节有关报告和隐私的内容。

提示

对于可能会在 Visual Studio 中发现的与 C++ 工具集无关的其他类型问题(例如,UI 问题、IDE 功能损坏或常规故障),请使用 IDE 中的“报告问题” 工具。 这是最佳选择,因为该工具具备屏幕截图功能,并且可以记录导致你所发现的问题的 UI 操作。 还可在 Visual Studio 开发者社区站点查找这些错误。 有关详细信息,请参阅如何报告 Visual Studio 的问题

报表和隐私

默认情况下,报告中的所有信息、评论和回复都是公开可见的。 一般来说,这是有好处的,因为这样整个社区都能看到其他用户发现的问题、解决方案和解决方法。 但是,如果担心数据或身份公开后会出现隐私或知识产权问题,则可另作选择。

如果担心身份泄露,请新建一个 Microsoft 帐户,该帐户不透露有关你的任何详细信息。 使用此帐户来创建报表。

不要在初始报表标题或内容中添加任何想要保密的内容,因为这会被公开。 相反,将以私密方式通过单独的评论发送详细信息。 为确保报表发送给正确的人员,请在问题报表的主题列表中加入 cppcompiler 。 创建问题报表后便可指定谁可以查看回复和附件。

创建私人信息问题报表

  1. 在创建的报表中,选择“添加注释”,创建对问题的私人说明 。

  2. 在回复编辑器中,使用“提交”和“取消”按钮下的下拉控件,指定可查看回复的群体 。 只有指定的人员能看到这些私人回复以及其中的图像、链接或代码。 选择“版主和贴主可见”,可仅允许 Microsoft 员工和自己查看 。

  3. 添加重现所需的说明和所有其他信息、图像和文件附件。 选择“提交”按钮将私下发送此信息 。

    附件大小不得超过 2 GB,最多可附加 10 个文件。 若要上传更大容量的内容,请在私人评论中申请获取上传网址。

同样,只有指定的人员能查看此注释下的所有回复。 即使回复上的下拉控件未正确显示可见性受限状态,仍是如此。

若要保留隐私并避免公众查看你的敏感信息,请谨慎授权。 将与 Microsoft 的所有交互保留在受限制的评论下的回复中。 回复其他评论可能会导致敏感信息意外泄露。

如何报告 C++ 文档问题

我们使用 GitHub 问题来跟踪文档中报告的问题。 现在可直接从内容页创建 GitHub 问题,这可帮助用户以更丰富的方式与文档作者和产品团队进行互动。 如果发现文档存在问题、错误代码示例、令人困惑的说明、关键信息的遗漏,甚至只是一个拼写错误,都请与我们联系。 滚动至本页底部,然后选择“登录以提供文档反馈” 。 如果没有 GitHub 帐户,需要创建一个 GitHub 帐户。 有了 GitHub 帐户后,可以看到所有文档问题及其状态。 对你报告的问题进行更改时,你还会收到通知。 有关详细信息,请参阅我们的反馈系统博客条目

在使用文档反馈按钮时,可以在 GitHub 上创建文档问题。 将使用有关创建问题的页面的一些信息自动填充此问题。 这是我们知道问题所在位置的途径,因此请勿编辑此信息。 只需要追加错误的详细信息和建议的修复方法(如果愿意)。 C++ docs 是开放源代码,因此,如果你想要自行提交修补程序,可以自行提交。 有关帮助改进文档的方式的详细信息,请参阅 GitHub 上的帮助指南