在VS2010中动态链接Boost 1.51.0时链接器错误LNK2019

时间:2012-10-03 18:33:28

标签: c++ visual-studio-2010 visual-studio boost linker

我正在使用BoostPro Computing安装程序安装的boost库。我在Windows 7 64位计算机上使用VS 2010。我想链接到动态提升,所以我选择了安装程序中的前两个选项(多线程调试DLL和多线程DLL,我相信它们被调用)。一些安装的库的示例是:

boost_bzip2-vc100-mt-1_51.lib
boost_bzip2-vc100-mt-gd-1_51.lib

在我的项目中链接到boost时,我也确保定义BOOST_ALL_DYN_LINK。我专门使用filesystem工具集。

当我打开BOOST_LIB_DIAGNOSTIC时,我在构建输出中看到以下消息:

1>  Linking to lib file: boost_filesystem-vc100-mt-gd-1_51.lib
1>  Linking to lib file: boost_system-vc100-mt-gd-1_51.lib

然而,这些很快就会跟进:

1>main.obj : error LNK2019: unresolved external symbol "__declspec(dllimport) public: class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const __thiscall boost::filesystem::path::string(void)const " (__imp_?string@path@filesystem@boost@@QBE?BV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@XZ) referenced in function _main
1>main.obj : error LNK2019: unresolved external symbol "__declspec(dllimport) public: __thiscall boost::filesystem::path::~path(void)" (__imp_??1path@filesystem@boost@@QAE@XZ) referenced in function _main
1>main.obj : error LNK2019: unresolved external symbol "__declspec(dllimport) class boost::filesystem::path __cdecl boost::filesystem::detail::unique_path(class boost::filesystem::path const &,class boost::system::error_code *)" (__imp_?unique_path@detail@filesystem@boost@@YA?AVpath@23@ABV423@PAVerror_code@system@3@@Z) referenced in function "class boost::filesystem::path __cdecl boost::filesystem::unique_path(class boost::filesystem::path const &)" (?unique_path@filesystem@boost@@YA?AVpath@12@ABV312@@Z)
1>main.obj : error LNK2019: unresolved external symbol "__declspec(dllimport) public: static class std::codecvt<wchar_t,char,int> const & __cdecl boost::filesystem::path::codecvt(void)" (__imp_?codecvt@path@filesystem@boost@@SAABV?$codecvt@_WDH@std@@XZ) referenced in function "public: __thiscall boost::filesystem::path::path<char const [20]>(char const (&)[20],void *)" (??$?0$$BY0BE@$$CBD@path@filesystem@boost@@QAE@AAY0BE@$$CBDPAX@Z)
1>main.obj : error LNK2019: unresolved external symbol "__declspec(dllimport) void __cdecl boost::filesystem::path_traits::convert(char const *,char const *,class std::basic_string<wchar_t,struct std::char_traits<wchar_t>,class std::allocator<wchar_t> > &,class std::codecvt<wchar_t,char,int> const &)" (__imp_?convert@path_traits@filesystem@boost@@YAXPBD0AAV?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@ABV?$codecvt@_WDH@5@@Z) referenced in function "void __cdecl boost::filesystem::path_traits::dispatch<class std::basic_string<wchar_t,struct std::char_traits<wchar_t>,class std::allocator<wchar_t> > >(class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const &,class std::basic_string<wchar_t,struct std::char_traits<wchar_t>,class std::allocator<wchar_t> > &,class std::codecvt<wchar_t,char,int> const &)" (??$dispatch@V?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@@path_traits@filesystem@boost@@YAXABV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@AAV?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@4@ABV?$codecvt@_WDH@4@@Z)
1>main.obj : error LNK2019: unresolved external symbol "__declspec(dllimport) class boost::system::error_category const & __cdecl boost::system::generic_category(void)" (__imp_?generic_category@system@boost@@YAABVerror_category@12@XZ) referenced in function "void __cdecl boost::system::`dynamic initializer for 'posix_category''(void)" (??__Eposix_category@system@boost@@YAXXZ)
1>main.obj : error LNK2019: unresolved external symbol "__declspec(dllimport) class boost::system::error_category const & __cdecl boost::system::system_category(void)" (__imp_?system_category@system@boost@@YAABVerror_category@12@XZ) referenced in function "void __cdecl boost::system::`dynamic initializer for 'native_ecat''(void)" (??__Enative_ecat@system@boost@@YAXXZ)

auto-link.hpp不应该为我处理我的链接吗?我并没有特别要求将任何内容链接到项目,因为自动链接器似乎正确识别所有内容。那我怎么会错过这些东西呢?此外,它们被声明为dllimport,因此链接器不应该单独留下它们并期望它们在运行时被发现?

谢谢!

UPDATE :我决定深入研究第二个链接器错误。它基本上说它无法找到path类的析构函数。在dumpbin库上运行filesystem后,我注意到文件中的

??1path@filesystem@boost@@QEAA@XZ (public: __cdecl boost::filesystem::path::~path(void))

但这显然与链接器正在寻找的内容不匹配,即:

"__declspec(dllimport) public: __thiscall boost::filesystem::path::~path(void)" (__imp_??1path@filesystem@boost@@QAE@XZ)

请注意,链接器正在寻找DLL导入版本,但是库本身似乎没有提供一个...不知道从哪里开始,但它似乎是重要的信息!

3 个答案:

答案 0 :(得分:5)

对我来说,这是因为“将wchar_t视为内置类型”选项设置为false,因此wchar_t被编译为unsigned short

答案 1 :(得分:4)

假设您已经编译了.lib,您需要确保.lib文件位于库路径中(查看VC ++目录 - &gt;库路径)。

编译器将在编译时放置DLL的链接,使用.lib发现正确的入口点等,以便在EXE / DLL在运行时启动时可以有效地加载它们。

您正在讨论的运行时DLL发现类型需要LoadLibrary + GetProcAddress类型代码,Boost不支持。

(静态链接实际上将来自经过统计编译的.lib代码的代码放入DLL / EXE中。)

编辑:此外,检查您是否正在使用正确的.lib文件作为您的目标,例如: 32位或64位。这将导致与签名类似的错误。

dumpbin /headers 

将告诉你为.lib构建的“机器”类型(dumpbin输出的第一部分)。

答案 2 :(得分:1)

(从您未解析的列表中)存在调用约定的差异。这将导致符号不匹配。我发现如果你尝试使用_ cdecl之外的其他编译作为Windows上的调用约定,1.54.0将无法编译所有库。 Windows喜欢许多不同的调用约定,它们不匹配( _cdecl / Gd,__ stdcall / Gz,__ FASTCALL / Gr) 另外,至少在1.54.0中我注意到有些库需要将wchar_t视为内置类型(Windows VS选项/ Zc:wchar_t)(确保boost :: log库)。这也会导致未解决的错误,因为在这种情况下,wchar_t与unsigned short不匹配。

相关问题