/MD、/MT、/LD(使用运行时库)

指示多线程模块是否为 DLL,并指定运行库的零售版本或调试版本。

语法

/MD[d]
/MT[d]
/LD[d]

备注

选项 说明
/MD 使此应用程序使用特定于多线程和 DLL 的运行库版本。 定义 _MT_DLL,并使编译器将库名 MSVCRT.lib 放入 .obj 文件中。

用此选项编译的应用程序静态链接到 MSVCRT.lib。 此库提供使链接器能够解析外部引用的代码的层。 实际工作代码包含在 MSVCRversionnumber.DLL 中,后者必须在运行时对与 MSVCRT.lib 链接的应用程序可用。
/MDd 定义 _DEBUG_MT_DLL,并使此应用程序使用特定于多线程和 DLL 的调试版本的运行库。 它还会让编译器将库名称 MSVCRTD.lib 放入 .obj 文件中。
/MT 使此应用程序使用运行库的多线程的静态版本。 定义 _MT,并使编译器将库名 LIBCMT.lib 放入 .obj 文件中,以便链接器使用 LIBCMT.lib 解析外部符号。
/MTd 定义 _DEBUG_MT。 此选项还会让编译器将库名称 LIBCMTD.lib 放置到 .obj 文件中,以便链接器将使用 LIBCMTD.lib 来解析外部符号。
/LD 创建一个 DLL。

/DLL 选项传递到链接器。 链接器查找 DllMain 函数,但并不需要该函数。 如果没有编写 DllMain 函数,则链接器将插入返回 TRUE 的 DllMain 函数。

链接 DLL 启动代码。

如果未在命令行上指定导出 (.exp) 文件,则创建导入库 (.lib)。 将导入库链接到调用 DLL 的应用程序。

/Fe (Name EXE File) 解释为命名 DLL 而不是 .exe 文件。 默认情况下,程序名会变成 basename.dll 而不是 basename.exe。

除非显式指定 /MD,否则将暗指 /MT
/LDd 创建调试 DLL。 定义 _MT_DEBUG

有关 C 运行时库以及使用 /clr(公共语言运行时编译)编译时使用的库的详细信息,请参阅 CRT 库功能

传递给链接器的给定调用的所有模块都必须使用相同的运行库编译器选项(/MD/MT/LD)进行编译。

有关如何使用运行库的调试版本的更多信息,请参见 C 运行时库参考

有关 DLL 的详细信息,请参阅在 Visual Studio 中创建 C/C++ DLL

在 Visual Studio 开发环境中设置此编译器选项

  1. 打开项目的“属性页” 对话框。 有关详细信息,请参阅在 Visual Studio 中设置 C++ 编译器和生成属性

  2. 选择“配置属性”>“C/C++”>“代码生成”属性页面

  3. 修改“运行库”属性。

以编程方式设置此编译器选项

另请参阅

MSVC 编译器选项
MSVC 编译器命令行语法