解决LNK4098:defaultlib'MSVCRT'与。冲突

这个警告:

LINK : warning LNK4098: defaultlib 'MSVCRT' conflicts
  with use of other libs; use /NODEFAULTLIB:library

在Visual Studio中是一个相当常见的警告。我想了解它的确切原因以及正确的方法(如果有的话)来处理它。

这出现在一个编译的调试版本中/MDd。该项目与windows之类的东西相关联,Version.dllpdh.dll与之相关MSVCRT.dll。显然,我没有这些的调试版本,无法编译它们。

所以我添加/NODEFAULTLIB:MSVCRT到链接器命令行,它实际上删除了警告。但这实际上做了什么?为什么有必要?


精慕HU
浏览 805回答 3
3回答

30秒到达战场

vc \ lib中有4个版本的CRT链接库:libcmt.lib:发布版本的静态CRT链接库(/ MT)libcmtd.lib:用于调试版本的静态CRT链接库(/ MTd)msvcrt.lib:CRT版本DLL版本的导入库(/ MD)msvcrtd.lib:CRT调试DLL版本的导入库(/ MDd)查看链接器选项,Project + Properties,Linker,Command Line。请注意这里没有提到这些库。链接器自动确定编译器使用了什么/ M开关,以及哪个.lib应通过#pragma comment指令链接。有点重要的是,如果/ M选项与您链接的.lib之间存在不匹配,则会出现可怕的链接错误并难以诊断运行时错误。当链接器被告知链接到msvcrt.lib 和 libcmt.lib 时,您将看到引用的错误消息。如果将使用/ MT编译的代码与使用/ MD链接的代码链接,将会发生这种情况。CRT只能有一个版本。/ NODEFAULTLIB告诉链接器忽略从/ MT编译代码生成的#pragma comment指令。这可能有效,尽管其他一些链接器错误并不少见。像errno这样的东西,它是静态CRT版本中的extern int,但是对DLL版本中的函数进行宏编辑。许多其他人喜欢这样。好吧,正确的方法修复此问题,找到您使用错误的/ M选项编译的链接的.obj或.lib文件。如果你没有线索,那么你可以通过点击.obj / .lib文件来找到它/“MT”顺便说一句:Windows可执行文件(如version.dll)有自己的CRT版本来完成他们的工作。它位于c:\ windows \ system32,您无法可靠地将它用于您自己的程序,其CRT标头在任何地方都无法使用。程序使用的CRT DLL具有不同的名称(如msvcrt90.dll)。

慕标琳琳

来自Yochai Timmer的 IMO 这个链接非常好,相关但很难阅读。我写了一个总结。Yochai,如果您读过这篇文章,请参阅最后的说明。对于原始帖子读取:警告LNK4098:defaultlib“LIBCD”与使用其他库冲突错误链接:警告LNK4098:defaultlib“LIBCD”与其他库的使用冲突; 使用/ NODEFAULTLIB:库含义系统的一部分被编译为使用单线程标准(libc)库与调试信息(libcd)静态链接而系统的另一部分被编译为使用多线程标准库而没有调试信息,这些信息驻留在DLL中并使用动态链接如何解决忽略警告,毕竟它只是一个警告。但是,您的程序现在包含多个相同功能的实例。使用链接器选项/ NODEFAULTLIB:lib。这不是一个完整的解决方案,即使你可以让你的程序以这种方式链接你忽略了一个警告标志:代码已经针对不同的环境进行了编译,你的一些代码可能被编译为单线程模型,而其他代码则是多线程。[...]浏览所有库并确保它们具有正确的链接设置在后者中,正如原始帖子中提到的那样,可能会出现两个常见问题:您有第三方库,其链接与您的应用程序不同。您的代码中嵌入了其他指令:通常这是MFC。如果系统中的任何模块与MFC链接,则所有模块必须名义上链接到相同版本的MFC。对于这些情况,请确保您了解问题并在解决方案中做出决定。
打开App,查看更多内容
随时随地看视频慕课网APP