Cl.exe编译器选项

MSVC编译器选项

优化

展开表
选项目的
/favor:<blend|AMD64|INTEL64|ATOM>生成针对一个指定体系结构或一系列体系结构进行优化的代码。
/O1创建小代码。
/O2创建快速代码。
/Ob<n>控制内联展开。
/Od禁用优化。
/Og已弃用。 使用全局优化。
/Oi[-]生成内部函数。
/Os代码大小优先。
/Ot代码速度优先。
/Ox不包含 /GF 或 /Gy 的 /O2 子集。
/Oy省略帧指针。 (仅限 x86)

代码生成

展开表
选项目的
/arch最低 CPU 架构要求。
/clr生成要在公共语言运行时上运行的输出文件。
/clr:implicitKeepAlive-关闭 System::GC::KeepAlive(this) 的隐式显示。
/clr:initialAppDomain启用 Visual C++ 2002 的初始 AppDomain 行为。
/clr:netcore生成以 .NET Core 运行时为目标的程序集。
/clr:noAssembly不要生成程序集。
/clr:nostdimport不要隐式导入任何必需的程序集。
/clr:nostdlib搜索程序集时忽略系统 .NET Framework 目录。
/clr:pure生成仅包含 IL 的输出文件(没有本机可执行代码)。
/clr:safe生成只包含 IL 的可验证输出文件。
/EHa启用 C++ 异常处理(出现 SEH 异常)。
/EHcextern "C" 默认为 nothrow
/EHr始终生成 noexcept 运行时终止检查。
/EHs启用 C++ 异常处理(无 SEH 异常)。
/feature启用体系结构功能。17.10
/fp:contract生成代码时考虑浮点收缩。
/fp:except[-]生成代码时考虑浮点异常。
/fp:fast“fast”浮点模型;结果可预测性较低。
/fp:precise“precise”浮点模型;结果可预测。
/fp:strict“strict”浮点模型(隐含 /fp:except)。
/fpcvt:BC向后兼容的浮点数到无符号整数的转换。
/fpcvt:IAIntel 本机浮点数到无符号整数的转换行为。
/fsanitize启用擦除器检测(如 AddressSanitizer)的编译。
/fsanitize-coverage为库(如 LibFuzzer)启用代码覆盖率检测的编译。
/GA针对 Windows 应用程序进行优化。
/Gd使用 __cdecl 调用约定。 (仅限 x86)
/Ge已弃用。 激活堆栈探测。
/GF启用字符串池。
/Gh调用挂钩函数 _penter
/GH调用挂钩函数 _pexit
/GL[-]启用全程序优化。
/Gm[-]已弃用。 启用最小重新生成。
/Gr使用 __fastcall 调用约定。 (仅限 x86)
/GR[-]启用运行时类型信息 (RTTI)。
/GS[-]检查缓冲区安全性。
/Gs[n]控制堆栈探测。
/GT支持使用静态线程本地存储分配的数据的纤程安全。
/Gu[-]确保 distinct 函数具有非重复地址。
/guard:cf[-]添加控制流防护安全检查。
/guard:ehcont[-]启用 EH 延续元数据。
/Gv使用 __vectorcall 调用约定。 (仅限 x86 和 x64)
/Gw[-]启用全程序全局数据优化。
/GX[-]已弃用。 启用同步异常处理。 请改用 /EH
/Gy[-]启用函数级链接。
/Gz使用 __stdcall 调用约定。 (仅限 x86)
/GZ已弃用。 启用快速检查。 (与 /RTC1 相同)
/homeparams强制将传入寄存器的参数写入其在函数入口的堆栈上的位置。 此编译器选项仅适用于 x64 编译器(本机编译和跨平台编译)。
/hotpatch创建可热修补的映像。
/jumptablerdata.rdata 节中放置 switch case 语句跳转表。
/Qfast_transcendentals生成快速先验。
/QIfist已弃用。 当需要从浮点型转换为整型时,取消调用 Helper 函数 _ftol 。 (仅限 x86)
/Qimprecise_fwaits移除 fwait 块中的 try 命令。
/QIntel-jcc-erratum缓解 Intel JCC Erratum 微代码更新的性能影响。
/Qpar启用循环的自动并行化。
/Qpar-report:n启用自动并行化的报告级别。
/Qsafe_fp_loads将整数移动指令用于浮点值,并禁用特定浮点加载优化。
/Qspectre[-]针对一类 Spectre 攻击启用 CVE 2017-5753 缓解措施。
/Qspectre-load为每个加载指令生成序列化指令。
/Qspectre-load-cf为每个加载内存的控制流指令生成序列化指令。
/Qvec-report:n启用自动矢量化的报告级别。
/RTC1启用快速运行时检查(相当于 /RTCsu)。
/RTCc在运行时转换为较小的类型检查。
/RTCs启用堆栈帧运行时检查。
/RTCu启用未初始化的本地使用情况检查。
/volatile:isoacquire/release 语义在 volatile 访问中不能得到保证。
/volatile:msacquire/release 语义在 volatile 访问中得到保证。

输出文件

展开表
选项目的
/doc将文档注释处理到一个 XML 文件中。
/FA配置程序集列表文件。
/Fa创建程序集列表文件。
/Fd重命名程序数据库文件。
/Fe重命名可执行文件。
/Fi指定预处理输出文件名。
/Fm创建映射文件。
/Fo创建对象文件。
/Fp指定预编译头文件名。
/FR, /Fr 命名生成的 .sbr 浏览器文件。 /Fr 已弃用。
/Ft<dir>#import 生成的头文件的位置。

预处理器

展开表
选项目的
/AI<dir>指定在解析传递到 #using 指令的文件引用时搜索的目录。
/C在预处理期间保留注释。
/D<name>{=|#}<text>定义常数和宏。
/E将预处理器输出复制到标准输出。
/EP将预处理器输出复制到标准输出。
/FI<file>预处理指定的包含文件。
/FU<file>强制使用文件名,就像它已被传递到 #using 指令一样。
/Fx将插入的代码与源文件合并。
/I<dir>在目录中搜索包含文件。
/P将预处理器输出写入文件。
/PD打印所有宏定义。
/PH预处理时生成 #pragma file_hash
/U<name>移除预定义宏。
/u移除所有的预定义宏。
/X忽略标准包含目录。

标头单元/模块

展开表
选项目的
/exportHeader创建由输入参数指定的标头单元文件 (.ifc)。
/headerUnit指定在何处查找指定标头的标头单元文件 (.ifc)。
/headerName根据指定的标头生成标头单元。
/ifcOutput指定生成的 .ifc 文件的输出文件名或目录。
/interface将输入文件视为模块接口单元。
/internalPartition将输入文件视为内部分区单元。
/reference使用命名模块 IFC。
/scanDependencies在 C++ 标准 JSON 窗体中列出模块和标头单元依赖项。
/sourceDependencies列出所有源级依赖项。
/sourceDependencies:directives列出模块和标头单元依赖项。
/translateInclude#include 视为 import

语言

展开表
选项目的
/await启用协同例程(可恢复函数)扩展。
/await:strict使用早期语言版本启用标准 C++20 协同例程支持。
/constexpr:backtrace<N>在诊断中显示 N 个 constexpr 评估(默认值:10)。
/constexpr:depth<N>constexpr 评估的递归深度限制(默认值:512)。
/constexpr:steps<N>在 N 步后终止 constexpr 评估(默认值:100000)
/openmp在源代码中启用 #pragma omp
/openmp:experimental启用 OpenMP 2.0 语言扩展并选择 OpenMP 3.0+ 语言扩展。
/openmp:llvm使用 LLVM 运行时的 OpenMP 语言扩展。
/permissive[-]设置标准一致性模式。
/std:c++14C++14 标准 ISO/IEC 14882:2014(默认)。
/std:c++17C++17 标准 ISO/IEC 14882:2017。
/std:c++20C++20 标准 ISO/IEC 14882:2020。
/std:c++latest最新的草案 C++ 标准预览功能。
/std:c11C11 标准 ISO/IEC 9899:2011。
/std:c17C17 标准 ISO/IEC 9899:2018。
/std:clatest最新的草案 C 标准预览功能。
/vd{0|1|2}取消或启用隐藏的 vtordisp 类成员。
/vmb对指向成员的指针使用最佳的基。
/vmg对指向成员的指针使用完全一般性。
/vmm声明多重继承。
/vms声明单一继承。
/vmv声明虚拟继承。
/Z7生成与 C 7.0 兼容的调试信息。
/Za在 C 代码中禁用某些 C89 语言扩展。
/Zc:__cplusplus[-]启用 __cplusplus 宏以报告支持的标准(默认关闭)。
/Zc:__STDC__启用 __STDC__ 宏以报告支持C标准(默认关闭)。
/Zc:alignedNew[-]启用 C++17 过度对齐的动态分配(在 C++17 中默认启用)。
/Zc:auto[-]auto 强制执行新的标准 C++ 含义(默认开启)。
/Zc:char8_t[-]启用或禁用作为 const char8_t 的 C++20 本机 u8 文本支持(默认关闭,在 /std:c++20 下除外)。
/Zc:enumTypes[-]为推断的 enum 基类型启用标准 C++ 规则(默认关闭,/permissive- 未隐含)。
/Zc:externC[-]extern "C" 函数(由 /permissive- 隐含)强制实施标准 C++ 规则。
/Zc:externConstexpr[-]constexpr 变量启用外部链接(默认关闭)。
/Zc:forScope[-]强制实施标准 C++ for 范围规则(默认开启)。
/Zc:gotoScope围绕局部变量初始化(/permissive- 隐含)强制实施标准 C++ goto 规则。
/Zc:hiddenFriend[-]强制实施标准 C++ 隐藏友元规则(由 /permissive- 隐含)
/Zc:implicitNoexcept[-]在所需函数上启用隐式 noexcept(默认开启)。
/Zc:inline[-]如果它们是 COMDAT 或仅具有内部链接,则删除未引用的函数或数据(默认关闭)。
/Zc:lambda[-]为泛型 lambda 中的一致性模式语法检查启用新的 lambda 处理器。
/Zc:noexceptTypes[-]强制实施 C++17 noexcept 规则(在 C++17 或更高版本中默认开启)。
/Zc:nrvo[-]启用可选复制和移动省略(默认在 /O2/permissive-/std:c++20 或更高版本下启用)。
/Zc:preprocessor[-]使用新的符合性预处理器(默认关闭,在 C11/C17 中除外)。
/Zc:referenceBinding[-]UDT 临时不会绑定到非 const lvalue 引用(默认关闭)。
/Zc:rvalueCast[-]强制实施标准 C++ 显式类型转换规则(默认关闭)。
/Zc:sizedDealloc[-]启用 C++14 全局大小解除分配函数(默认开启)。
/Zc:strictStrings[-]禁用字符串文本到 char*wchar_t* 的转换(默认关闭)。
/Zc:templateScope[-]强制实施标准 C++ 模板参数阴影规则(默认关闭)。
/Zc:ternary[-]对操作数类型强制实施条件运算符规则(默认关闭)。
/Zc:threadSafeInit[-]启用线程安全的本地静态初始化(默认开启)。
/Zc:throwingNew[-]假设 operator new 在失败时引发(默认关闭)。
/Zc:tlsGuards[-]生成 TLS 变量初始化的运行时检查(默认启用)。
/Zc:trigraphs启用三元组(已过时,默认关闭)。
/Zc:twoPhase[-]使用不符合模板分析行为(默认符合)。
/Zc:wchar_t[-]wchar_t 是本机类型,而不是 typedef(默认开启)。
/Zc:zeroSizeArrayNew[-]为 0 大小的对象数组调用成员 new/delete(默认开启)。
/Ze已弃用。 启用 C89 语言扩展。
/Zf在并行生成中改进 PDB 生成时间。
/ZH:[MD5|SHA1|SHA_256]为调试信息中的校验和指定 MD5、SHA-1 或 SHA-256。
/ZI将调试信息包含在与“编辑并继续”兼容的程序数据库中。 (仅限 x86)
/Zi生成完整的调试信息。
/Zl.obj 文件中移除默认库名。
/Zo[-]为优化的代码生成更丰富的调试信息。
/Zp[n]封装结构成员。
/Zs只检查语法。
/ZW生成要在 Windows 运行时上运行的输出文件。

链接

展开表
选项目的
/F设置堆栈大小。
/LD创建动态链接库。
/LDd创建调试动态链接库。
/link将指定的选项传递给 LINK。
/LN创建 MSIL .netmodule
/MD使用 MSVCRT.lib 编译以创建多线程 DLL。
/MDd使用 MSVCRTD.lib 编译以创建调试多线程 DLL。
/MT使用 LIBCMT.lib 编译以创建多线程可执行文件。
/MTd使用 LIBCMTD.lib 编译以创建调试多线程可执行文件。

杂项

展开表
选项目的
/?列出编译器选项。
@指定响应文件。
/analyze启用代码分析。
/bigobj增加 .obj 文件中可寻址节的数目。
/c编译但不链接。
/cgthreads指定 cl.exe 线程数以用于优化和代码生成。
/errorReport已弃用。 Windows 错误报告 (WER) 设置控制错误报告。
/execution-charset设置执行字符集。
/fastfail启用快速失败模式。
/FC在诊断文本中显示传递给 cl.exe 的源代码文件的完整路径。
/FS强制写入到 PDB 文件以通过 MSPDBSRV.EXE 序列化。
/H已弃用。 限制外部(公共)名称的长度。
/HELP列出编译器选项。
/J更改默认的 char 类型。
/JMC支持本机 C++“仅我的代码”调试。
/kernel编译器和链接器创建可在 Windows 内核中执行的二进制文件。
/MP同时生成多个源文件。
/nologo取消显示登录版权标志。
/presetPadding将基于堆栈的类类型的填充初始化为零。
/showIncludes在编译期间显示所有包含文件的列表。
/source-charset设置源字符集。
/Tc指定 C 源文件。
/TC指定所有源文件都是 C。
/Tp指定 C++ 源文件。
/TP指定所有源文件都是 C++。
/utf-8将源和执行字符集设置为 UTF-8。
/V已弃用。 设置版本字符串。
/validate-charset验证 UTF-8 文件以仅查找兼容的字符。
/volatileMetadata对易失存储器访问生成元数据。
/Yc创建 .PCH 文件。
/Yd已弃用。 将完整的调试信息放在所有对象文件中。 请改用 /Zi
/Yl创建调试库时插入 PCH 引用。
/Yu在生成期间使用预编译头文件。
/Y-忽略当前生成中的所有其他预编译头编译器选项。
/Zm指定预编译头内存分配限制。

诊断

展开表
选项目的
/diagnostics:caret[-]诊断格式:打印列和指示的源行。
/diagnostics:classic使用旧诊断格式。
/diagnostics诊断格式:打印列信息。
/external:anglebrackets将通过 <> 包含的所有标头视为外部标头。
/external:env:<var>指定具有外部标头位置的环境变量。
/external:I <path>指定外部标头的位置。
/external:templates[-]跨模板实例化链评估警告等级。
/external:W<n>设置外部标头的警告等级。
/options:strict无法识别的编译器选项是错误。
/sdl启用更多安全功能和警告。
/w禁用所有警告。
/W0、、/W1/W2/W3/W4设置输出警告等级。
/w1<n>、、/w2<n>/w3<n>、、/w4<n>针对指定的警告设置警告等级。
/Wall启用所有警告,包括默认情况下禁用的警告。
/wd<n>禁用指定的警告。
/we<n>将指定的警告视为错误。
/WL在从命令行编译 C++ 源代码时启用错误消息和警告消息的单行诊断。
/wo<n>仅显示一次指定的警告。
/Wv:xx[.yy[.zzzzz]]禁用编辑器的指定版本后引入的警告。
/WX将警告视为错误。

实验性选项

实验性选项只能由某些版本的编译器支持。 它们也可能在不同的编译器版本中表现不同。 实验性选项的最佳或唯一文档通常位于 Microsoft C++ 团队博客中。

展开表
选项目的
/experimental:log启用试验性结构化 SARIF 输出。
/experimental:module启用实验性模块支持。

已弃用并删除的编译器选项

展开表
选项目的
/clr:noAssembly已弃用。 改用 /LN(创建 MSIL 模块)
/errorReport已弃用。 错误报告由 Windows 错误报告 (WER) 设置控制。
/experimental:preprocessor已弃用。 启用符合实验性的预处理器支持。 使用 /Zc:preprocessor
/Fr已弃用。 创建无局部变量的浏览信息文件。
/Ge已弃用。 激活堆栈探测。 默认已启用。
/Gm已弃用。 启用最小重新生成。
/GX已弃用。 启用同步异常处理。 请改用 /EH
/GZ已弃用。 启用快速检查。 请改用 /RTC1
/H已弃用。 限制外部(公共)名称的长度。
/Og已弃用。 使用全局优化。
/QIfist已弃用。 曾用来指定如何从浮点类型转换到整型类型。
/V已弃用。 设置 .obj 文件版本字符串。
/Wp64已过时。 检测 64 位可移植性问题。
/Yd已弃用。 将完整的调试信息放在所有对象文件中。 请改用 /Zi
/Zc:forScope-已弃用。 在 for 循环范围中禁用一致性。
/Ze已弃用。 启用 语言扩展。
/Zg已在 Visual Studio 2015 中删除。 生成函数原型。

17.10 从 Visual Studio 2022 版本 17.10 开始,此选项可用。

另请参阅

C/C++ 生成参考
MSVC 编译器选项
MSVC 编译器命令行语法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值