You can use #pragma comment(lib...) to specify linker options in Microsoft C++

Заявление об отказе от обязательств для неподдерживаемых продуктов

Эта статья содержит сведения о продуктах, поддержка которых корпорацией Майкрософт прекращена. Поэтому она предлагается «как есть» и обновляться не будет.


The comment pragma allows the user to insert comments into an object file or executable file. The lib specifier allows the user to pass this comment to the linker to specify additional libraries to link when using the object module. Some users utilize the lib comment pragma to add linker options as well as library names, such as:

#pragma comment(lib, "MSVCRT -VERBOSE")
This line, under Visual C++ 2.x, would pass the string to the linker as is, resulting in the addition of the /VERBOSE linker option as well as the MSVCRT.LIB library. This behavior was not specified to work in this manner. The compiler wouldn't put quotes around comment string, so spaces would delimit the text.

In Visual C++ 4.x and later, the compiler correctly puts quotes around the comment string thereby causing the above code to generate the following error:
LINK : fatal error LNK1104: cannot open file "MSVCRT -VERBOSE.lib"


Use the following new pragma to specify linker options:

#pragma comment(linker, "<linker options>")


This behavior is by design.

More Information

Sample code to reproduce the behavior:

// Compile options needed: none
// Compile the code in Visual C++ 4.x or later
// test.c

#pragma comment(lib,"MYLIBRARY -VERBOSE")

void main(void)
You will receive the following error message:
LINK : fatal error LNK1104: cannot open file "MYLIBRARY -VERBOSE.lib"


For more information about#pragma directives , see the following MSDN Web site:

Номер статьи: 153901 — последний просмотр: 18 июня 2012 г. — редакция: 1

Отзывы и предложения