Fin*_*ter 3 c++ windows dll linker
我的问题非常类似于这个:DLL中的类有一个静态成员.在这种情况下,静态成员是QString类型(QT类型)并为类提供名称.我提供了类级别的正常导出:__declspec(dllexport).
当我将DLL与我的类链接到另一个项目并尝试编译它时,我得到静态数据的"未解析的外部符号"错误.我验证了两件事:
DLL中的HEADER文件(.h)是:
class __declspec(dllexport) MyClass {
public:
virtual ~MyClass();
static const QString JUST_A_NAME;
};
Run Code Online (Sandbox Code Playgroud)
DLL中的IMPLEMENTATION文件(.cpp)是:
#include "MyClass.h"
MyClass::~MyClass() { }
const QString MyClass::JUST_A_NAME("call_me_al");
Run Code Online (Sandbox Code Playgroud)
与已经提到的帖子相比,我避免使用内联方法,例如实现显然不在标题中.类型QString(参见第83行ff.)本身包含几个内联.可能导致错误?
编辑:我在我的应用程序的标题中添加了一个import语句.它位于任何包含之前. APPLICATION中的HEADER文件(.h)是:
class __declspec(dllimport) MyClass {
public:
virtual ~MyClass();
static const QString JUST_A_NAME;
};
Run Code Online (Sandbox Code Playgroud)
错误保持不变:
error LNK2001: non resolved external symbol ""public: static class QString const MyClass::JUST_A_NAME" (?JUST_A_NAME@MyClass@@2VQString@@B)". <name of .obj file from application>
Run Code Online (Sandbox Code Playgroud)
在您的应用程序头文件中,您需要做两件事.
__declspec(dllexport)__declspec(dllimport)你显然不能同时做到这两件事.
你要做的是定义一个像这样的宏:
#ifdef __COMPILING_MYLIB
#define MYLIBAPI __declspec(dllimport)
#else
#define MYLIBAPI __declspec(dllexport)
#endif
Run Code Online (Sandbox Code Playgroud)
然后像这样声明你的导出:
// mylib.h
class MYLIBAPI MyClass {
public:
virtual ~MyClass();
static const QString JUST_A_NAME;
};
Run Code Online (Sandbox Code Playgroud)
然后,在编译MYLIB时,您将传递-D__COMPLING_MYLIB给编译器,从而触发#if上述操作.
这样,在编译库本身时,头文件将事物声明为导出,但在编译将使用库的东西时,它们被声明为导入.
| 归档时间: |
|
| 查看次数: |
3286 次 |
| 最近记录: |