症状:
当 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)
"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)
"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)
"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)
MSVCRTD.LIB (dllmain.obj)
mfcs42d.lib(dllmodul.obj):error LNK2005:_DllMain@12 already defined in
msvcrtd.lib(dllmain.obj)
msvcrtd.lib(dllmain.obj)
原因:
CRT 库对
new、
delete 和
DllMain 函数使用弱外部链接。MFC 库也包含
new、
delete 和
DllMain 函数。这些函数要求先链接 MFC 库,然后再链接 CRT 库。
该问题有两种解决方法。第一种方法是强制链接器按照正确的顺序链接库。第二种方法是由您亲自查找导致问题的模块并纠正它。
解决方案一:强制链接器按照正确的顺序链接库
- 右键工程-》属性-》linker->Input->Ignore Specific Liabary 填写Nafxcwd.lib;Libcmtd.lib
- 在 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)