我阅读了一些文档,这些文档给出了与C兼容的函数的简单示例。
__declspec(dllexport) MyFunction();
我很开心。我写了一个小应用程序使用这个dll的功能。我使用显式链接
LoadLibrary()
功能。 C风格的功能没有问题。但是当我把我的课写成
时namespace DllTest
{
class Test
{
public:
__declspec(dllexport) Test();
__declspec(dllexport) void Function( int );
__declspec(dllexport) int getBar(void);
private:
int bar;
};
}
#endif
它编译得很好并且创建了Dll。使用C风格函数时,我只是从LoadLibrary()和GetProcAddress(...)函数中获取函数指针。
我之前的用法是
typedef void (*Function)(int);
int main()
{
Function _Function;
HINSTANCE hInstLibrary = LoadLibrary(TEXT("test.dll"));
if (hInstLibrary)
{
_Function = (Function)GetProcAddress(hInstLibrary,"Function");
if (_Function)
{
// use the function
但现在我不知道如何实例化我的课程? 我如何使用显式链接或隐式链接?
对代码示例的任何帮助都将不胜感激。
答案 0 :(得分:6)
如果您正在尝试实例化一个类,那么您需要在编译时知道它的结构。您可以通过创建一个抽象类来实现此目的,该类定义导入的类必须重新定义的实例方法。例如:
//interface.h
class TestInterface
{
public:
virtual void Function( int ) = 0;
virtual int getBar(void) = 0;
};
然后,在你的DLL中,你可以包含interface.h,继承TestInterface并重新定义纯虚方法:
//test.h
namespace DllTest {
class Test : public TestInterface
{
public:
Test();
void Function( int );
int getBar(void);
private:
int bar;
};
};
然后,您可以在DLL中定义一个分配Test对象的函数:
extern "C" __declspec(dllexport) TestInterface *allocate_test() {
return new DllTest::Test();
}
最后,当您导入DLL时,请查找符号“allocate_test”并使用它:
TestInterface *(*test_fun)() = (TestInterface *(*test_fun)())GetProcAddress(hInstLibrary,"allocate_test");
TestInterface *test_ptr = test_fun();
test_ptr->Function(12); //use you object
答案 1 :(得分:2)
首先,请注意这是微软的特殊性。不同的规则 将适用于其他系统。
像你一样写东西不起作用,或者至少是痛苦的。您
需要在DLL中使用__declspec(dllexport)
来定义
函数,但在编译调用的代码时__declspec(dllimport)
来自另一个DLL的函数。通常的处理方法是
使用一些指定DLL的特定宏名称,并执行以下操作:
#ifdef __WIN32
#ifdef MYMODULE_DLL
#define MYMODULE_EXPORT __declspec(dllexport)
#else
#define MYMODULE_EXPORT __declspec(dllimport)
#endif
#else
#define MYMODULE_EXPORT
#endif
将它放在标题中,该标题包含在您的所有标题中
DLL,并在项目的命令行上定义MYMODULE_DLL
。
此外,还可以导出整个班级:
class MYMODULE_EXPORT DllTest
{
// ...
};
这具有导出或导入所有功能的效果 该类的静态成员。