我是靠谱客的博主 清爽灯泡,最近开发中收集的这篇文章主要介绍cl.exe 命令行cl.exe链接器用法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

使用命令后编绎 c++源文件

一。没有设置环境变量 时,指定include /lib 的中的路径

B:VisualStudioVC98Bin>cl.exe main.cpp /I ../include /link ../lib/libc.lib ../lib/oldnames.lib ../lib/KERNEL32.lib

二。设置环境变量 

1、设置环境变量:

PATH=C:Program FilesMicrosoft Visual Studio 8VCbin

INCLUDE=C:Program FilesMicrosoft Visual Studio 8VCinclude

LIB=C:Program FilesMicrosoft Visual Studio 8VClib

附:VC++6.0编译语法解释

VC- Project Setting-Debug-Project Option语法解释
-优化-
/O1 最小化空间 minimize space
/Op[-] 改善浮点数一致性 improve floating-pt consistency
/O2 最大化速度 maximize speed
/Os 优选代码空间 favor code space
/Oa 假设没有别名 assume no aliasing
/Ot 优选代码速度 favor code speed
/Ob 内联展开(默认 n=0) inline expansion (default n=0)
/Ow 假设交叉函数别名 assume cross-function aliasing
/Od 禁用优化(默认值) disable optimizations (default)
/Ox 最大化选项。(/Ogityb2 /Gs) maximum opts. (/Ogityb1 /Gs)
/Og 启用全局优化 enable global optimization
/Oy[-] 启用框架指针省略 enable frame pointer omission
/Oi 启用内建函数 enable intrinsic functions

-代码生成-
/G3 为 80386 进行优化 optimize for 80386
/G4 为 80486 进行优化 optimize for 80486
/GR[-] 启用 C++ RTTI enable C++ RTTI
/G5 为 Pentium 进行优化 optimize for Pentium
/G6 为 Pentium Pro 进行优化 optimize for Pentium Pro
/GX[-] 启用 C++ 异常处理(与 /EHsc 相同) enable C++ EH (same as /EHsc)
/EHs 启用同步 C++ 异常处理 enable synchronous C++ EH
/GD 为 Windows DLL 进行优化 optimize for Windows DLL
/GB 为混合模型进行优化(默认) optimize for blended model (default)
/EHa 启用异步 C++ 异常处理 enable asynchronous C++ EH
/Gd __cdecl 调用约定 __cdecl calling convention
/EHc extern“C”默认为 nothrow extern "C" defaults to nothrow
/Gr __fastcall 调用约定 __fastcall calling convention
/Gi[-] 启用增量编译 enable incremental compilation
/Gz __stdcall 调用约定 __stdcall calling convention
/Gm[-] 启用最小重新生成 enable minimal rebuild
/GA 为 Windows 应用程序进行优化 optimize for Windows Application
/Gf 启用字符串池 enable string pooling
/QIfdiv[-] 启用 Pentium FDIV 修复 enable Pentium FDIV fix
/GF 启用只读字符串池 enable read-only string pooling
/QI0f[-] 启用 Pentium 0x0f 修复 enable Pentium 0x0f fix
/Gy 分隔链接器函数 separate functions for linker
/GZ 启用运行时调试检查 enable runtime debug checks
/Gh 启用钩子函数调用 enable hook function call
/Ge 对所有函数强制堆栈检查 force stack checking for all funcs
/Gs[num] 禁用堆栈检查调用 disable stack checking calls

-输出文件-
/Fa[file] 命名程序集列表文件 name assembly listing file
/Fo 命名对象文件 name object file
/FA[sc] 配置程序集列表 configure assembly listing
/Fp 命名预编译头文件 name precompiled header file
/Fd[file] 命名 .PDB 文件 name .PDB file
/Fr[file] 命名源浏览器文件 name source browser file
/Fe 命名可执行文件 name executable file
/FR[file] 命名扩展 .SBR 文件 name extended .SBR file
/Fm[file] 命名映射文件 name map file

-预处理器-
/FI 命名强制包含文件 name forced include file
/C 不吸取注释 don't strip comments
/U 移除预定义宏 remove predefined macro
/D{=|#} 定义宏 define macro
/u 移除所有预定义宏 remove all predefined macros
/E 将预处理定向到标准输出 preprocess to stdout
/I 添加到包含文件的搜索路径 add to include search path
/EP 将预处理定向到标准输出,不要带行号 preprocess to stdout, no #line
/X 忽略“标准位置” ignore "standard places"
/P 预处理到文件 preprocess to file

-语言-
/Zi 启用调试信息 enable debugging information
/Zl 忽略 .OBJ 中的默认库名 omit default library name in .OBJ
/ZI 启用调试信息的“编辑并继续”功能 enable Edit and Continue debug info
/Zg 生成函数原型 generate function prototypes
/Z7 启用旧式调试信息 enable old-style debug info
/Zs 只进行语法检查 syntax check only
/Zd 仅要行号调试信息 line number debugging info only
/vd{0|1} 禁用/启用 vtordisp disable/enable vtordisp
/Zp[n] 在 n 字节边界上包装结构 pack structs on n-byte boundary
/vm 指向成员的指针类型 type of pointers to members
/Za 禁用扩展(暗指 /Op) disable extensions (implies /Op)
/noBool 禁用“bool”关键字 disable "bool" keyword
/Ze 启用扩展(默认) enable extensions (default)

- 杂项 -
/?, /help 打印此帮助消息 print this help message
/c 只编译,不链接 compile only, no link
/W 设置警告等级(默认 n=1) set warning level (default n=1)
/H 最大化外部名称长度 max external name length
/J 默认 char 类型是 unsigned default char type is unsigned
/nologo 取消显示版权消息 suppress copyright message
/WX 将警告视为错误 treat warnings as errors
/Tc 将文件编译为 .c compile file as .c
/Yc[file] 创建 .PCH 文件 create .PCH file
/Tp 将文件编译为 .cpp compile file as .cpp
/Yd 将调试信息放在每个 .OBJ 中 put debug info in every .OBJ
/TC 将所有文件编译为 .c compile all files as .c
/TP 将所有文件编译为 .cpp compile all files as .cpp
/Yu[file] 使用 .PCH 文件 use .PCH file
/V 设置版本字符串 set version string
/YX[file] 自动的 .PCH 文件 automatic .PCH
/w 禁用所有警告 disable all warnings
/Zm 最大内存分配(默认为 %) max memory alloc (% of default)

Microsoft Visual C++ Toolkit 2003 下载链接

cl.exe所在的文件夹里面有一个批处理叫做

VSVAR32.BAT
首先运行它一次,你就可以用cl.exe来编译你的代码了。
(在vs2005里面未发现该文件,怀疑因该是上级目录的vcvarsall.bat,但是不执行该文件同样可进行命令行编译。)
CL.exe 是控制 Microsoft C 和 C++ 编译器与链接器的 32 位工具。编译器产生通用对象文件格式 (COFF) 对象 (.obj) 文件。链接器产生可执行文件 (.exe) 或动态链接库文件 (DLL)。

注意,所有编译器选项都区分大小写。

若要编译但不链接,请使用 /c。

使用 NMAKE 生成输出文件。

使用 BSCMAKE 支持类浏览。

以下是一个完整的编译器选项分类列表。

优化

选项 作用
/O1 创建小代码
/O2 创建快速代码
/Oa 假设没有别名
/Ob 控制内联展开
/Od 禁用优化
/Og 使用全局优化
/Oi 生成内部函数
/Op 改善浮点数一致性
/Os 代码大小优先
/Ot 代码速度优先
/Ow 假定在函数调用中使用别名
/Ox 使用最大优化 (/Ob1gity /Gs)
/Oy 省略框架指针

代码生成

选项 作用
/clr 启用 C++ 的托管扩展并产生在公共语言运行库上运行的输出文件
/EH 指定异常处理模型
/G3 优化代码以优选 386 处理器。在 Visual C++ 5.0 中已经停用,编译器将忽略此选项
/G4 优化代码以优选 486 处理器。在 Visual C++ 5.0 中已经停用,编译器将忽略此选项
/G5 优化代码以优选 Pentium
/GB 与 /G6 等效;将 _M_IX86 的值设置为 600
/Gd 使用 __cdecl 调用约定
/Ge 激活堆栈探测
/GF
/GF 启用字符串池
/GH 调用挂钩函数 _penter
/GH 调用挂钩函数 _pexit
/GL 启用全程序优化
/Gm 启用最小重新生成
/Gr 启用运行时类型信息 (RTTI)
/Gr 使用 __fastcall 调用约定
/GS 控制堆栈探测
/GT 支持使用静态线程本地存储区分配的数据的纤程安全
/GX 启用同步异常处理
/Gy 启用函数级链接
/GZ 使用 __stdcall 调用约定
/MD 使用 MSVCRT.lib 创建多线程 DLL
/MDd 使用 MSVCRTD.lib 创建调试多线程 DLL
/ML 使用 LIBC.lib 创建单线程可执行文件
/MLd 使用 LIBCD.lib 创建调试单线程可执行文件
/MT 使用 LIBCMT.lib 创建多线程可执行文件
/MTd 使用 LIBCMTD.lib 创建调试多线程可执行文件

输出文件

选项 作用
/FA
/FA 创建汇编文件
设置列表文件名
/Fd 重命名程序数据库文件
/Fe 重命名可执行文件
/Fm 创建映射文件
/Fo 创建对象文件
/Fp 指定预编译头文件名
/FR
/FR 生成浏览器文件
/Fx 将插入的代码与源文件合并

调试

选项 作用
/GS 缓冲区安全检查
/GZ 与 /RTC1 相同
/RTC 启用运行时错误检查
/Wp64 检测 64 位可移植性问题
/Yd 将完整的调试信息放在所有对象文件中
/Yl 创建调试库时插入 PCH 引用
/Z7 生成与 C 7.0 兼容的调试信息
/Zd 生成行号
/Zi 生成完整的调试信息

预处理器

选项 作用
/AI 指定在解析传递到#using 指令的文件引用时搜索的目录
/c 在预处理期间保留注释
/D 定义常数和宏
/E 将预处理器输出复制到标准输出
/EP 将预处理器输出复制到标准输出
/Fl 预处理指定的包含文件
/FU 强制使用文件名,就像它已被传递到#using 指令一样
/I 在目录中搜索包含文件
/P 将预处理器输出写入文件
/U 移除预定义宏
/U 移除所有的预定义宏
/X 忽略标准包含目录
/ZI 将调试信息包含在与“编辑并继续”兼容的程序数据库中

语言

选项 作用
/noBool 取消 C++ bool、true 和 false 关键字
/vd 取消或启用隐藏的 vtordisp 类成员
/vmb 对指向成员的指针使用最佳的基
/vmg 对指向成员的指针使用完全一般性
/vmm 声明多重继承
/vms 声明单一继承
/vmv 声明虚拟继承
/Za 禁用语言扩展
/Zc 在 /Ze 下指定标准行为
/Ze 启用语言扩展
/Zg 生成函数原型
/Zl 从 .obj 文件中移除默认库名
/Zp n 封装结构成员
/Zs 只检查语法

链接

选项 作用
/F 设置堆栈大小
/LD 创建动态链接库
/LDd 创建调试动态链接库
/link 将指定的选项传递给 LINK
/MD 使用 MSVCRT.lib 编译以创建多线程 DLL
/MDd 使用 MSVCRTD.lib 编译以创建调试多线程 DLL
/ML 使用 LIBC.lib 编译以创建单线程可执行文件
/MLd 使用 LIBCD.lib 编译以创建调试单线程可执行文件
/MT 使用 LIBCMT.lib 编译以创建多线程可执行文件
/MTd 使用 LIBCMTD.lib 编译以创建调试多线程可执行文件

预编译头

选项 作用
/Y- 忽略当前生成中的所有其他预编译头编译器选项
/Yc 创建预编译头文件
/Yd 将完整的调试信息放在所有对象文件中
/Yu 在生成期间使用预编译头文件
/YX 自动处理预编译头

杂项

选项 作用
@ 指定响应文件
/? 列出编译器选项
/c 编译但不链接
/H 限制外部(公共)名称的长度
/HELP 列出编译器选项
/J 更改默认的 char 类型
/NOLOGO 取消显示登录版权标志
/QI0f 确保 Pentium 0F 指令没有问题
/QIfdiv FDIV、FPREM、FPTAN 和 FPATAN 指令有缺陷的 Intel Pentium 微处理器的变通方法
QIfist 当需要从浮点类型转换为整型时取消 Helper 函数 _ftol 的调用
/showIncludes 在编译期间显示所有包含文件的列表
/Tc
/Tc 指定 C 源文件
/Tp
/Tp 指定 C++ 源文件
/V 设置版本字符串
/w 设置警告等级
/w 禁用所有警告
/Wall 启用所有警告,包括默认情况下禁用的警告
/WL 在从命令行编译 C++ 源代码时启用错误信息和警告消息的单行诊断
/Zm 设置编译器的内存分配限制


CL 命令行使用下列语法:

CL [option...] file... [option | file]... [lib...] [@command-file] [/link link-opt...]

下表说明CL 命令的输入项意义

option 一个或多个 CL 选项。请注意,所有选项都应用于所有指定的源文件。选项是由一个正斜杠 (/) 或一个短划线 (–) 指定的。如果某个选项带有参数,则该选项的说明指定在选项和参数之间是否允许有空格。选项名(/HELP 选项除外)区分大小写。有关更多信息,请参阅 CL 选项的顺序。

file 一个或多个源文件、.obj 文件或库的名称。CL 编译源文件并将 .obj 文件和库的名称传递给链接器。有关更多信息,请参阅 CL 文件名语法。

lib 一个或多个库名。CL 将这些名称传递给链接器。

command-file 包含多个选项和文件名的文件。有关更多信息,请参阅 CL 命令文件。

link-opt 一个或多个链接器选项。CL 将这些选项传递给链接器。

您可以指定任意数目的选项、文件名和库名,条件是命令行上的字符数不超过 1024,该限制是操作系统指定的。



CL 命令文件请参见
设置编译器选项 | 编译器选项
命令文件是一个文本文件,它包含您另外在命令行上键入或使用 CL 环境变量指定的选项和文件名。CL 接受在 CL 环境变量中或命令行上用作参数的编译器命令文件。与命令行或 CL 环境变量不同,命令文件允许使用多行选项和文件名。

命 令文件中的选项和文件名将根据 CL 环境变量中或命令行上的命令文件名的位置被进行处理。但是,如果 /link 选项出现在命令文件中,则该行其余部分的所有选项将被传递给链接器。命令文件的后面几行中的选项和命令行上命令文件调用之后的选项仍被作为编译器选项接 受。

命令文件一定不能包含 CL 命令。每个选项必须在同一行上开始和结束;不能使用反斜杠 (") 跨行组合一个选项。

命令文件用一个 @ 符后接一个文件名指定;该文件名可指定绝对路径或相对路径。

使用CL.EXE查看C++中类的内存结构

今天查资料的时候发现 VS 编译器 CL 的一个编译选项可以查看 C++ 类的内存布局,非常有用。使用如下,从开始程序菜单找到 Visual Stdio 2008/2005 Command Prompt,选择 VS 的命令行工具,按如下格式使用:

>cl –d1reportSingleClassLayout[classname]  test.cpp

而使用 –d1reportAllClassLayout 则可以查看源文件中所有类及结构体的内存布局。

其中,classname 为类名,-d1reportSingleClassLayout[classname] 之间没有空格。编写程序测试:

比较奇怪,加上 #include <iostream> 后,测试结构体的时候就会出现很输出,应该是库中的类,看起来真麻烦,所以这里去掉它。

和在IDE中编译相比,命令行模式编译速度更快,并可以避免被IDE产生的一些附加信息所干扰。本文将介绍微软C/C++编译器命令行模式设定和用法。

1、设置环境变量:

PATH=C:Program FilesMicrosoft Visual Studio 8VCbin

INCLUDE=C:Program FilesMicrosoft Visual Studio 8VCinclude

LIB=C:Program FilesMicrosoft Visual Studio 8VClib

如果提示找不到mspdb80.dll文件,则从C:Program FilesMicrosoft Visual Studio 8Common7IDE下拷贝“msobj80.dll,mspdb80.dll,mspdbcore.dll,mspdbsrv.exe”这四个文件到C:Program FilesMicrosoft Visual Studio 8VCbin下即可。



2、命令选项:

1)       /C:在预处理输出中保留注释语句

2)       /c:只编译,不连接,相当于在"Build"菜单下选择了"Compile"

3)       /D:定义常量和宏,与源程序里的#define 有相同效果

4)       /E:预处理C、C++源文件,将源文件中所有的预编译指令及宏展开,将注释去掉,然后将预处理器的输出拷贝至标准输出设备输出,并且在每个文件的开头和末尾加入#line

5)       /EH:指定编译器用何种异常处理模型

6)       /EP:同/E,只是去掉了#line

7)       /F:设置程序的堆栈大小

8)       /FA:设置生成何种列表文件(汇编、汇编与机器码、汇编与源码、汇编与机器码以及源码)

9)       /Fa:指定用/FA设置的列表文件的存放路径及(或)文件名

10) /FD:生成文件的相互依赖信息

11) /Fd:设置程序数据库文件(PDB)的存放路径及(或)文件名

12) /Fe:设置最终可执行文件的存放路径及(或)文件名

13) /FI:预处理指定的头文件,与源文件中的#include有相同效果

14) /Fm:创建map文件

15) /Fo:设置编译后Obj文件的存放路径及(或)文件名

16) /Fp:设置预编译文件(pch)的存放路径及(或)文件名

17) /FR:生成浏览信息(sbr)文件

18) /Fr:同/FR,不同之处在于/Fr不包括局部变量信息

19) /G3:为80386处理器优化代码生成

20) /G4:为80486处理器优化代码生成

21) /G5:为Pentium处理器优化代码生成

22) /G6:为Pentium Pro处理器优化代码生成

23) /GA:为Windows应用程序作优化

24) /GB:为Pentium处理器优化代码生成,使用80386、80486、Pentium、Pentium Pro的混合指令集,是代码生成的默认选项(程序属性选项中Processor对应Blend)

25) /GD:为Windows动态库(dll)作优化,此开关在VC6中没有实现

26) /Gd:指定使用__cdecl的函数调用规则

27) /Ge:激活堆栈检测

28) /GF:消除程序中的重复的字符串,并将她放到只读的缓冲区中

29) /Gf:消除程序中的重复字符串

30) /Gh:在每个函数的开头调用钩子(hook)函数--penter

31) /Gi:允许渐进编译

32) /Gm:允许最小化rebuild

33) /GR:允许运行时类型信息(Run-Time Type Infomation)

34) /Gr:指定使用__fastcall的函数调用规则

35) /Gs:控制堆栈检测所用内存大小

36) /GT:支持用__declspec(thread)分配的数据的fier-safety

37) /GX:允许同步异常处理,与/EHsc开关等价

38) /Gy:允许编译器将每一个函数封装成COMDATs的形式,供连接器调用

39) /GZ:允许在Debug build 的时候捕捉Release build的错误

40) /Gz:指定使用__stdcall的函数调用规则

41) /H:限制外部名字的长度

42) /HELP:列出编译器的所有的命令开关

43) /I:指定头文件的搜索路径

44) /J:将char的缺省类型从signed char改成unsigned char

45) /LD:创建一个动态连接库

46) /LDd:创建一个Debug版本的动态链接库

47) /link:将指定的选项传给连接器

48) /MD:选择多线程、DLL版本的C Run-Time库

49) /MDd:选择多线程、DLL、Debug版本的C Run-Time库

50) /ML:选择单线程版本的C Run—Time库

51) /MLd:选择单线程、Debug版本的C Run—Time库

52) /MT:选择多线程版本的C Run-Time库

53) /MTd:选择多线程、Debug版本的C Run—Time库

54) /nologo:不显示程序的版权信息

55) /O1:优化使产生的可执行代码最小

56) /O2:优化使产生的可执行代码速度最快

57) /Oa:指示编译器程序里没有使用别名,可以提高程序的执行速度

58) /Ob:控制内联(inline)函数的展开

59) /Od:禁止代码优化

60) /Og:使用全局优化

61) /Oi:用内部函数去代替程序里的函数调用,可以使程序运行的更快,但程序的长度变长

62) /Op:提高浮点数比较运算的一致性

63) /Os:产生尽可能小的可执行代码

64) /Ot:产生尽可能块的可执行代码

65) /Ow:指示编译器在函数体内部没有使用别名

66) /Ox:组合了几个优化开关,达到尽可能多的优化

67) /Oy:阻止调用堆栈里创建帧指针

68) /Q1f:对核心级的设备驱动程序生成单独的调试信息

69) /QI0f:对Pentium 0x0f错误指令作修正

70) /Qifdiv:对Pentium FDIV错误指令作修正

71) /P:将预处理输出写到指定文件里,文件的后缀名为I

72) /TC:将命令行上的所有文件都当作C源程序编译,不管后缀名是否为.c

73) /Tc:将指定的文件当作C源程序编译,不管后缀名是否为.c

74) /TP:将命令行上的所有文件都当作C++源程序编译,不管后缀名是否为.cpp

75) /Tp:将指定文件当作C++源程序编译,不管后缀名是否为.cpp

76) /U:去掉一个指定的前面定义的符号或常量

77) /u:去掉所有前面定义的符号或常量

78) /V:在编译的obj文件里嵌入版本号

79) /vd:禁止/允许构造函数置换

80) /vmb:选择指针的表示方法,使用这个开关,在声明指向某个类的成员的指针之前,必须先定义这个类

81) /vmg:选择指针的表示方法,使用这个开关,在声明指向某个类的成员的指针之前,不必先定义这个类,但要首先指定这个类是使用何种继承方法

82) /vmm:设置指针的表示方法为Single Inheritance and Multiple Inheritance

83) /vms:设置指针的表示方法为Single Inheritance

84) /vmv:设置指针的表示方法为Any class

85) /W:设置警告等级

86) /w:禁止所有警告

87) /X:阻止编译器搜索标准的include 目录

88) /Yc:创建预编译头文件(pch)

89) /Yd:在所有的obj文件里写上完全的调试信息

90) /Yu:在build过程中使用指定的预编译头文件

91) /YX:指示编译器若预编译头文件存在,则使用它,若不存在,则创建一个

92) /Z7:生成MSC7.0兼容的调试信息

93) /Za:禁止语言扩展(Microsoft Extensions to C)

94) /Zd:调试信息只包含外部和全局的符号信息以及行号信息

95) /Ze:允许语言扩展(Microsoft Extensions to C)

96) /Zg:为源文件里面定义的每个函数生成函数原型

97) /ZI:生成程序库文件(Pdb)并支持Edit and Continue调试特性

98) /Zi:生成程序库文件(pdb),包含类型信息和符号调试信息

99) /ZL:从obj文件里去掉缺省的库文件名

100)            /Zm:设置编译器的内存分配xianzhi

101)            /Zn:禁止浏览信息文件里面的封装

102)            /Zp:设置结构成员在内存里面的封装格式

103)            /Zs:快速检查语法错误

--------------------------

vc所支持的文件类型

1)       DSW:全称是Developer Studio Workspace,最高级别的配置文件,记录了整个工作空间的配置信息,她是一个纯文本的文件,在vc创建新项目的时候自动生成

2)       DSP:全称是Developer Studio Project,也是一个配置文件,不过她记录的是一个项目的所有配置信息,纯文本文件

3)       OPT:与DSW、DSP配合使用的配置文件,她记录了与机器硬件有关的信息,同一个项目在不同的机器上的opt文件内容是不同的

4)       CLW:记录了跟ClassWizard相关的信息,如果丢失了clw文件,那么在Class View面板里就没有类信息

5)       PLG:实际上是一个超文本文件,可以用Internet Explorer打开,记录了Build的过程,是一个日志型文件

6)       RC:资源描述文件,记录了所有的资源信息,在资源编辑器里作的修改,实际上都是对RC文件的修改

7)       RC2:附加的资源描述文件,不能直接资源编辑器修改,只能手工添加,可以用来添加额外的资源

8)       RES:经过资源编辑器编译之后的资源文件,以二进制方式存放

9)       SBR:编译器生成的浏览信息文件,在代码导航的时候非常有用,她需要在编译时指定/FR或者/Fr开关

10) BSC:BSCMAKE.EXE将所有的SBR文件作为输入,经过处理之后输出一个BSC文件,在代码导航的时候实际用到的是BSC文件

11) ILK:当选定渐增型编译连接时,连接器自动生成ILK文件,记录连接信息

12) PDB:全称是Program DataBase,即程序数据库文件,用来记录调试信息,是一个相当重要的文件,没有他,程序无法正常调试

13) LIB:如果项目输出是Dll的话,一般会输出一个跟项目同名的Lib文件,记录输出的函数信息

14) EXP:同Lib,是跟Dll一起生成的输出文件

15) PCH:全称是PreCompiled Header,就是预先编译好的头文件,在编译时指定/Yu开关时编译器自动生成




2008-11-14 17:15

CL.exe   是控制   Microsoft   C   和   C++   编译器与链接器的   32   位工具。编译器产生通用对象文件格式   (COFF)   对象   (.obj)   文件。链接器产生可执行文件   (.exe)   或动态链接库文件   (DLL)。 
   
注意,所有编译器选项都区分大小写。 
   
若要编译但不链接,请使用   /c。 
   
使用   NMAKE   生成输出文件。 
   
使用   BSCMAKE   支持类浏览。 
   
以下是一个完整的编译器选项分类列表。 
   
优化 
   
选项   作用    
/O1   创建小代码    
/O2   创建快速代码    
/Oa   假设没有别名    
/Ob   控制内联展开    
/Od   禁用优化    
/Og   使用全局优化    
/Oi   生成内部函数    
/Op   改善浮点数一致性    
/Os   代码大小优先    
/Ot   代码速度优先    
/Ow   假定在函数调用中使用别名    
/Ox   使用最大优化   (/Ob1gity   /Gs)    
/Oy   省略框架指针    
   
代码生成 
   
选项   作用    
/clr   启用   C++   的托管扩展并产生在公共语言运行库上运行的输出文件    
/EH   指定异常处理模型    
/G3   优化代码以优选   386   处理器。在   Visual   C++   5.0   中已经停用,编译器将忽略此选项    
/G4   优化代码以优选   486   处理器。在   Visual   C++   5.0   中已经停用,编译器将忽略此选项    
/G5   优化代码以优选   Pentium    
/GB   与   /G6   等效;将   _M_IX86   的值设置为   600    
/Gd   使用   __cdecl   调用约定    
/Ge   激活堆栈探测    
/GF 
/GF   启用字符串池    
/GH   调用挂钩函数   _penter    
/GH   调用挂钩函数   _pexit    
/GL   启用全程序优化    
/Gm   启用最小重新生成    
/Gr   启用运行时类型信息   (RTTI)    
/Gr   使用   __fastcall   调用约定    
/GS   控制堆栈探测    
/GT   支持使用静态线程本地存储区分配的数据的纤程安全    
/GX   启用同步异常处理    
/Gy   启用函数级链接    
/GZ   使用   __stdcall   调用约定    
/MD   使用   MSVCRT.lib   创建多线程   DLL    
/MDd   使用   MSVCRTD.lib   创建调试多线程   DLL    
/ML   使用   LIBC.lib   创建单线程可执行文件    
/MLd   使用   LIBCD.lib   创建调试单线程可执行文件    
/MT   使用   LIBCMT.lib   创建多线程可执行文件    
/MTd   使用   LIBCMTD.lib   创建调试多线程可执行文件    
   
输出文件 
   
选项   作用    
/FA 
/FA   创建列表文件 
设置列表文件名    
/Fd   重命名程序数据库文件    
/Fe   重命名可执行文件    
/Fm   创建映射文件    
/Fo   创建对象文件    
/Fp   指定预编译头文件名    
/FR 
/FR   生成浏览器文件    
/Fx   将插入的代码与源文件合并    
   
调试 
   
选项   作用    
/GS   缓冲区安全检查    
/GZ   与   /RTC1   相同    
/RTC   启用运行时错误检查    
/Wp64   检测   64   位可移植性问题    
/Yd   将完整的调试信息放在所有对象文件中    
/Yl   创建调试库时插入   PCH   引用    
/Z7   生成与   C   7.0   兼容的调试信息    
/Zd   生成行号    
/Zi   生成完整的调试信息    
   
预处理器 
   
选项   作用    
/AI   指定在解析传递到#using   指令的文件引用时搜索的目录    
/c   在预处理期间保留注释    
/D   定义常数和宏    
/E   将预处理器输出复制到标准输出    
/EP   将预处理器输出复制到标准输出    
/Fl   预处理指定的包含文件    
/FU   强制使用文件名,就像它已被传递到#using   指令一样    
/I   在目录中搜索包含文件    
/P   将预处理器输出写入文件    
/U   移除预定义宏    
/U   移除所有的预定义宏    
/X   忽略标准包含目录    
/ZI   将调试信息包含在与“编辑并继续”兼容的程序数据库中    
   
语言 
   
选项   作用    
/noBool   取消   C++   bool、true   和   false   关键字    
/vd   取消或启用隐藏的   vtordisp   类成员    
/vmb   对指向成员的指针使用最佳的基    
/vmg   对指向成员的指针使用完全一般性    
/vmm   声明多重继承    
/vms   声明单一继承    
/vmv   声明虚拟继承    
/Za   禁用语言扩展    
/Zc   在   /Ze   下指定标准行为    
/Ze   启用语言扩展    
/Zg   生成函数原型    
/Zl   从   .obj   文件中移除默认库名    
/Zp   n   封装结构成员    
/Zs   只检查语法    
   
链接 
   
选项   作用    
/F   设置堆栈大小    
/LD   创建动态链接库    
/LDd   创建调试动态链接库    
/link   将指定的选项传递给   LINK    
/MD   使用   MSVCRT.lib   编译以创建多线程   DLL    
/MDd   使用   MSVCRTD.lib   编译以创建调试多线程   DLL    
/ML   使用   LIBC.lib   编译以创建单线程可执行文件    
/MLd   使用   LIBCD.lib   编译以创建调试单线程可执行文件    
/MT   使用   LIBCMT.lib   编译以创建多线程可执行文件    
/MTd   使用   LIBCMTD.lib   编译以创建调试多线程可执行文件    
   
预编译头 
   
选项   作用    
/Y-   忽略当前生成中的所有其他预编译头编译器选项    
/Yc   创建预编译头文件    
/Yd   将完整的调试信息放在所有对象文件中    
/Yu   在生成期间使用预编译头文件    
/YX   自动处理预编译头    
   
杂项 
   
选项   作用    
@   指定响应文件    
/?   列出编译器选项    
/c   编译但不链接    
/H   限制外部(公共)名称的长度    
/HELP   列出编译器选项    
/J   更改默认的   char   类型    
/NOLOGO   取消显示登录版权标志    
/QI0f   确保   Pentium   0F   指令没有问题    
/QIfdiv   FDIV、FPREM、FPTAN   和   FPATAN   指令有缺陷的   Intel   Pentium   微处理器的变通方法    
QIfist   当需要从浮点类型转换为整型时取消   Helper   函数   _ftol   的调用    
/showIncludes   在编译期间显示所有包含文件的列表    
/Tc 
/Tc   指定   C   源文件    
/Tp 
/Tp   指定   C++   源文件    
/V   设置版本字符串    
/w   设置警告等级    
/w   禁用所有警告    
/Wall   启用所有警告,包括默认情况下禁用的警告    
/WL   在从命令行编译   C++   源代码时启用错误信息和警告消息的单行诊断    
/Zm   设置编译器的内存分配限制    
CL   命令行使用下列语法: 
   
CL   [option...]   file...   [option   |   file]...   [lib...]   [@command-file]   [/link   link-opt...] 
   
下表说明CL   命令的输入项意义    
   
option   一个或多个   CL   选项。请注意,所有选项都应用于所有指定的源文件。选项是由一个正斜杠   (/)   或一个短划线   (–)   指定的。如果某个选项带有参数,则该选项的说明指定在选项和参数之间是否允许有空格。选项名(/HELP   选项除外)区分大小写。有关更多信息,请参阅   CL   选项的顺序。      
   
file   一个或多个源文件、.obj   文件或库的名称。CL   编译源文件并将   .obj   文件和库的名称传递给链接器。有关更多信息,请参阅   CL   文件名语法。      
   
lib   一个或多个库名。CL   将这些名称传递给链接器。    
   
command-file   包含多个选项和文件名的文件。有关更多信息,请参阅   CL   命令文件。    
   
link-opt   一个或多个链接器选项。CL   将这些选项传递给链接器。    
   
您可以指定任意数目的选项、文件名和库名,条件是命令行上的字符数不超过   1024,该限制是操作系统指定的。

cl.exe链接器用法

weixin_30636089

于 2010-07-26 16:44:00 发布163 收藏

文章标签: c/c++ 嵌入式 shell

版权

CL.exe 是控制 Microsoft C 和 C++ 编译器与链接器的 32 位工具。编译器产生通用对象文件格式 (COFF)
对象 (.obj) 文件。链接器产生可执行文件 (.exe) 或动态链接库文件 (DLL)。

注意,所有编译器选项都区分大小写。
---------------------------------------------------------------------------------------------
用法如下:
  CL [option...] file... [option | file]... [lib...] [@command-file] [/link link-opt...]

      option      : 一个或多个 CL 选项。请注意,所有选项都应用于所有指定的源文件。选项是由一个
                    正斜杠 (/) 或一个短划线 (-) 指定的。如果某个选项带有参数,则该选项的说明指
                    定在选项和参数之间是否允许有空格。选项名(/HELP 选项除外)区分大小写。有关
                    更多信息,请参见 CL 选项的顺序。
         /c    : 编译但不链接
         /Zs   : 检查语法
  /?    : 列出编译器选项
         /arch : 使用 SSE 或 SSE2 指令生成代码
           /arch:SSE2
  /clr  : 启用 C++ 的托管扩展并产生在公共语言运行库上运行的输出文件 
         /F    : 设置堆栈大小    |   此选项设置程序堆栈大小(以字节为单位)。
                如果不使用此选项,堆栈大小默认为 1 MB
           /F 100
         /Fe   : 重命名可执行文件
           /Feexe.exe
  /G7   :针对 Pentium 4 或 Athlon 优化代码。
  /GA   :优化 Windows 应用程序的代码
  /GL   :启用全程序优化
  /Gm   :启用最小重新生成
  /HELP :列出编译器选项
  /I    :在目录中搜索包含文件 | 指定源文件目录 include
     /I"e:VCinclude"
  /link : 将指定的选项传递给 LINK
  /MD   : 使用 MSVCRT.lib 创建多线程 DLL
  /ML   : 使用 LIBC.lib 创建单线程可执行文件
  /MT   : 使用 LIBCMT.lib 创建多线程可执行文件
  /O1   : 创建小代码
  /O2   : 创建快速代码
  /Os   : 代码大小优先
         /W    : 设置警告等级
     /W3
 ------------------------------
  /Ot   : 代码速度优先
  /LD   : 创建动态链接库
  /Ox   : 使用最大优化

  /Zs   : 只检查语法
 ------------------------------
         /TC   : 指定 C 源文件
  /TP   : 指定 C++ 源文件
-----------------------------------------------------------------------------------------
      file        : 一个或多个源文件、.obj 文件或库的名称。CL 编译源文件并将 .obj 文件和库的名
                    称传递给链接器。有关更多信息,请参见 CL 文件名语法。 
      lib         : 一个或多个库名。CL 将这些名称传递给链接器。
      command-file: 包含多个选项和文件名的文件。有关更多信息,请参见 CL 命令文件。
      link-opt    : 一个或多个链接器选项。CL 将这些选项传递给链接器
---------------------------------------------------------------------------------------------
精典用法:
      cl *.cpp /G7 /MD /Ox /Ot /W3 /c /EHsc /I"G:Visual C++VC98PlatformSDKInclude"
---------------------------------------------------------------------------------------------
LINK 是将通用对象文件格式 (COFF) 对象文件和库链接起来以创建 32 位可执行 (.exe) 文件或动态链接
库 (DLL) 的 32 位工具。

LINK  用法如下:

  /ALIGN 指定每一节的对齐方式
 /ALIGN 选项指定程序线性地址空间中每一节的对齐方式。number 参数以字节为单位,并且必须是2 的幂。默认值是 4K (4096)。如果对齐方式产生
               无效的图像,则链接器发出警告。除非正
               在编写诸如设备驱动程序的应用程序,否则应不需要修改对齐方式。
  /DLL 生成 DLL
  /DRIVER 创建 Windows NT 核心模式驱动程序
  /EXETYPE 生成虚拟设备驱动程序
  /EXETYPE:DYNAMIC  创建动态加载的虚拟设备驱动程序。
  /EXETYPE:DEV386   创建静态加载的虚拟设备驱动程序。这是                                    /EXETYPE 的默认值
  /INCREMENTAL 控制增量链接
  /LARGEADDRESSAWARE 通知编译器应用程序支持大于 2 GB 的地址
  /LIBPATH 允许用户重写环境库路径
  /LIBPATH:"e:VCLIB" /LIBPATH:"e:DXLIB"
  /MACHINE 指定目标平台
 ` /MACHINE:{AM33|ARM|EBC|IA64|M32R|MIPS|MIPS16|MIPSFPU|MIPSFPU16|
               MIPSR41XX|SH3|SH3DSP|SH4|SH5|THUMB|X86|        X64/*8.0版本*/}
   /MACHINE:X86
  /NOENTRY 创建纯资源 DLL
  创建纯资源 DLL 时要求 /NOENTRY 选项。
  /OPT 控制 LINK 优化
  如果生成仅运行于 Windows NT 或 Windows 2000 上的组件,则应使用 /OPT:NOWIN98。
  /SUBSYSTEM: 指定子系统
              {CONSOLE|EFI_APPLICATION|EFI_BOOT_SERVICE_DRIVER|
              EFI_ROM|EFI_RUNTIME_DRIVER|NATIVE|POSIX|WINDOWS|
              WINDOWSCE}[,#[.##]]
  /OUT 指定输出文件名
  /OUT:Hello.exe

精典用法:
link *.obj rc.res /LIBPATH:"G:Visual C++lib" /SUBSYSTEM:WINDOWS /MACHINE:X86 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib OpenGL32.Lib

rc 是资源编译
     /l 列出资源用的区域性
 0x804 中国
 0x409 美国 
 用法:
  rc /l 0x804 file.rc
 
---------------------------------------------------------------------------------------------
MFC 开发如下:
  编译源代码:
 cl *.cpp /Ox /Ot /G7 /D "WIN32" /D "_WINDOWS" /D "_AFXDLL" /EHsc /MD /arch:SSE2 /W3 /c
  资源编译  :
 rc /l 0x804 winmfc.rc
  链接      :
 link *.obj WinMFC.res /out:WinMFC.exe /OPT:NOWIN98 /SUBSYSTEM:WINDOWS /MACHINE:X86

最后

以上就是清爽灯泡为你收集整理的cl.exe 命令行cl.exe链接器用法的全部内容,希望文章能够帮你解决cl.exe 命令行cl.exe链接器用法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(63)

评论列表共有 0 条评论

立即
投稿
返回
顶部