该宏放置一个注释到对象文件或者可执行文件。函数
#pragma comment( comment-type [,"commentstring"] )
comment-type是一个预约义的标识符,指定注释的类型,应该是compiler,exestr,lib,linker之一。
commentstring是一个提供为comment-type提供附加信息的字符串,
Remarks:
一、compiler:放置编译器的版本或者名字到一个对象文件,该选项是被linker忽略的。
二、exestr:在之后的版本将被取消。
三、lib:放置一个库搜索记录到对象文件中,这个类型应该是和commentstring(指定你要Liner搜索的lib的名称和路径)
这个库的名字放在Object文件的默认库搜索记录的后面,linker搜索这个这个库就像你在命令行输入这个命令同样。你能够
在一个源文件中设置多个库记录,它们在object文件中的顺序和在源文件中的顺序同样。若是默认库和附加库的次序是须要
区别的,使用Z编译开关是防止默认库放到object模块。
四、linker:指定一个链接选项,这样就不用在命令行输入或者在开发环境中设置了。
只有下面的linker选项能被传给Linker.
/DEFAULTLIB工具
/EXPORTspa
/INCLUDE命令行
/MANIFESTDEPENDENCY对象
/MERGE索引
/SECTION开发
(1)/DEFAULTLIB:library
/DEFAULTLIB 选项将一个 library 添加到 LINK 在解析引用时搜索的库列表。用 /DEFAULTLIB 指定的库在命令行上指定的库以后和 .obj 文件中指定的默认库以前被搜索。
忽略全部默认库 (/NODEFAULTLIB) 选项重写 /DEFAULTLIB:library。若是在二者中指定了相同的 library 名称,忽略库 (/NODEFAULTLIB:library) 选项将重写 /DEFAULTLIB:library。字符串
(2)/EXPORT:entryname[,@ordinal[,NONAME]][,DATA]编译器
使用该选项,能够从程序导出函数,以便其余程序能够调用该函数。也能够导出数据。一般在 DLL 中定义导出。entryname 是调用程序要使用的函数或数据项的名称。ordinal 在导出表中指定范围在 1 至 65,535 的索引;若是没有指定 ordinal,则 LINK 将分配一个。NONAME 关键字只将函数导出为序号,没有 entryname。string
DATA 关键字指定导出项为数据项。客户程序中的数据项必须用 extern __declspec(dllimport) 来声明。
有三种导出定义的方法,按照建议的使用顺序依次为:
源代码中的 __declspec(dllexport)
.def 文件中的 EXPORTS 语句
LINK 命令中的 /EXPORT 规范
全部这三种方法能够用在同一个程序中。LINK 在生成包含导出的程序时还建立导入库,除非生成中使用了 .exp 文件。
LINK 使用标识符的修饰形式。编译器在建立 .obj 文件时修饰标识符。若是 entryname 以其未修饰的形式指定给连接器(与其在源代码中同样),则 LINK 将试图匹配该名称。若是没法找到惟一的匹配名称,则 LINK 发出错误信息。当须要将标识符指定给连接器时,请使用 Dumpbin 工具获取该标识符的修饰名形式。
(3)/INCLUDE:symbol
/INCLUDE 选项通知连接器将指定的符号添加到符号表。
若要指定多个符号,请在符号名称之间键入逗号 (,)、分号 (;) 或空格。在命令行上,对每一个符号指定一次 /INCLUDE:symbol。
连接器经过将包含符号定义的对象添加到程序来解析 symbol。该功能对于添包含不会连接到程序的库对象很是有用。用该选项指定符号将经过 /OPT:REF 重写该符号的移除。
咱们常常用到的是#pragma comment(lib,"*.lib")这类的。#pragma comment(lib,"Ws2_32.lib")表示连接Ws2_32.lib这个库。 和在工程设置里写上链入Ws2_32.lib的效果同样,不过这种方法写的 程序别人在使用你的代码的时候就不用再设置工程settings了