6

我有一个 VS2008 本机 C++ 项目,我希望将其编译为 DLL。

它只引用一个外部库(log4cplus.lib),并使用它的功能。(自然也使用 log4cplus 的 .h 文件)。

当我尝试将我的项目编译为静态库时,它成功了。当我尝试作为 DLL 时,它失败了:

1>MessageWriter.obj : error LNK2019: unresolved external symbol "public: static class log4cplus::Logger __cdecl log4cplus::Logger::getInstance(class std::basic_string<wchar_t,struct std::char_traits<wchar_t>,class std::allocator<wchar_t> > const &)" (?getInstance@Logger@log4cplus@@SA?AV12@ABV?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@@Z) referenced in function "class log4cplus::Logger __cdecl Log(void)" (?Log@@YA?AVLogger@log4cplus@@XZ)

还有 4 个与 log4cplus.lib 中的函数相关的错误。

这似乎真的很愚蠢..请帮助我:)

谢谢!

编辑 :

我链接到 log4cplus.lib 文件,它发现它很好。此外,log4cplus.lib 是 100% 功能的,我在另一个项目中使用它没有问题。我的初衷是将我的项目编译为静态库并在我正在编写的另一个 DLL 中使用它,但是当这样做时,我在另一个项目中得到相同的链接器错误......

编辑#2:

导致链接器错误的函数是静态函数。这可能是问题的一部分吗?

4

7 回答 7

6

wilx 是对的。我有同样的链接问题。

我花了将近一天的时间来解决这个问题。

我已经下载了log4cplus-1.0.4,在我用visual studio 2010打开这个项目后,编译它,静态库和动态库,没有错误。

但是,当我尝试使用这些库时,无论是静态库还是动态库,都会出现链接错误。

原因是,默认情况下,那些项目使用多字节字符,但是,我自己的项目使用 unicode,所以,为了解决这些链接问题,你只需要更改一个项目的字符集。

unicode 或多字节字符集。

并在 Visual Studio 2010 中更改一个项目的字符集,请参见以下链接。

如何在 VC++ 项目中关闭 Unicode?

于 2011-06-24T05:04:56.570 回答
4

创建静态库时,库创建者不会尝试解析您正在使用的所有函数(log2cplus.lib 中的函数)。当您创建与您的静态库链接的可执行文件时,会解析这些函数。

当您创建动态库时,库创建者(链接器)会尝试解析您正在使用的所有函数。构建动态库后,您必须立即为链接器提供 log4cplus.lib 库。您不能等到创建可执行文件。

于 2010-05-17T11:28:15.797 回答
3

无论哪种情况,您都需要链接库。

不同之处在于,当您静态链接时 - 所有功能都通过您正在使用的库链接。

当您动态链接时,您链接到具有从 dll 加载和使用函数的功能的导入库,而您缺少此步骤。通常导入库与您链接的 dll 具有相同的名称。

编辑:

我看到缺少的符号不是 '__imp...' 这意味着头文件没有为动态链接“配置”,可能是因为您在包含 Log4Cplus 标头的项目中定义或LOG4CPLUS_BUILD_DLL未定义。log4cplus_EXPORTSDLL_EXPORT

于 2010-05-17T11:33:44.380 回答
2

您实际上是在链接 log2cplus.lib 文件吗?如果您正在编译为静态库,那么您将通过最终的 .exe 链接到它,而不是在静态库中 - 也许这就是区别?

于 2010-05-17T11:27:17.950 回答
0

如果您使用的是 MSVC 之类的编译器,那么在从 lib 更改为 dll 时,它可能在您不知道的情况下更改了项目设置。您应该仔细检查在 DLL 模式下,您已正确链接到 lib。

于 2010-05-17T11:31:44.867 回答
0

我可以看到链接器错误有两种可能性:

  1. 您已经使用提供的 Release 构建配置编译了 log4cplus.dll(和关联的 log4cplus.lib 导入库),但现在您的应用程序使用“字符集”选项设置为“使用 Unicode 字符集”进行编译

  2. 或者您正在尝试使用 log4cplus 的静态库,但为您的应用程序定义 LOG4CPLUS_BUILD_DLL。

我打赌第一。它可能是别的东西,仍然。你用的是什么版本的 log4cplus?

如果要在应用程序中使用 log4cplus.dll,请定义 LOG4CPLUS_BUILD_DLL 符号。log4cplus_EXPORTS 和 DLL_EXPORT 仅支持基于 CMake 的构建系统,以及分别在 MingGW 上基于 autotools 的构建系统。

于 2010-05-18T09:05:19.287 回答
0

您是否使用了 __declspec(dllimport) 和 __declspec(dllexport)?

它们在链接静态库时不是必需的,但对于 DLL 是必需的。该函数必须声明为导出(在 DLL 中),因此用户可以在外部使用它(从而从 DLL 中导入它)。

也许这可以帮助:

使用 __declspec(dllimport) 导入应用程序

http://msdn.microsoft.com/en-us/library/8fskxacy%28VS.80%29.aspx

此致

于 2010-05-17T11:28:26.700 回答