CRT和MFC库的冲突--lnk2005错误

症状:

当 C 运行时 (CRT) 库和 Microsoft 基础类 (MFC) 库的链接顺序有误时,可能会出现以下 LNK2005 错误之一:

nafxcwd.lib(afxmem.obj) :error LNK2005:
"void * __cdecl operator new(unsigned int)"(??2@YAPAXI@Z) already
defined in LIBCMTD.lib(new.obj)
nafxcwd.lib(afxmem.obj) :error LNK2005:
"void __cdecl operator delete(void *)"(??3@YAXPAX@Z) already defined
in LIBCMTD.lib(dbgnew.obj)
nafxcwd.lib(afxmem.obj) :error LNK2005:
"void * __cdecl operator new(unsigned int,int,char const *,int)"
(??2@YAPAXIHPBDH@Z) already defined in LIBCMTD.lib(dbgnew.obj)
mfcs40d.lib(dllmodul.obj):error LNK2005:_DllMain@12 already defined in
MSVCRTD.LIB (dllmain.obj)
mfcs42d.lib(dllmodul.obj):error LNK2005:_DllMain@12 already defined in
msvcrtd.lib(dllmain.obj)
原因:
CRT 库对 newdeleteDllMain 函数使用弱外部链接。MFC 库也包含 newdeleteDllMain 函数。这些函数要求先链接 MFC 库,然后再链接 CRT 库。
该问题有两种解决方法。第一种方法是强制链接器按照正确的顺序链接库。第二种方法是由您亲自查找导致问题的模块并纠正它。

解决方案一:强制链接器按照正确的顺序链接库

  1. 右键工程-》属性-》linker->Input->Ignore Specific Liabary   填写Nafxcwd.lib;Libcmtd.lib
  2. 在 linker->Input->Additional Dependencies    填写Nafxcwd.lib Libcmtd.lib

原理:该方法通过先忽略掉Nafxcwd.lib;Libcmtd.lib(因为这两个库是IDE的默认库) 然后再强制连接器按照正确的顺序链接库;

 

 

我的解决方案:

      我的问题也是 new, delete already defined;  我们游戏引擎自定义了new, delete等操作,恰好VC2008 Feather Pack

也自定义了这两个操作。也就出现了这个lnk 2005问题;

      我研究了半天, 无法强制两者的链接顺序,     不过把 工程属性-》General   | Use of MFC   调成Use MFC in a Shared DLL 就没有问题了。   (我原来是用的Use MFC in a Static Library)

你可能感兴趣的:(Microsoft,delete,mfc,dll,library,dependencies)