导出具有命名空间的函数和类。源代码如下:
头文件MiniMFC.h
namespace MiniMFC
{
__declspec(dllexport) void f();
class __declspec(dllexport) MyClass
{
public:
void Mf();
};
}
实现文件MiniMFC.cpp
#include "stdafx.h"
#include <iostream>
using namespace std;
#include "MiniMFC.h"
using namespace MiniMFC;
void MyClass::Mf()
{
cout << "I‘m MiniMFC::MyClass::Mf() from DLL" << endl;
}
void f()
{
cout << "I‘m MiniMFC::f() from DLL" << endl;
}
最终生成的dll文件中并没有导出void f()
函数。使用dependency Walker查看结果为:
??4MyClass@MiniMFC@@QAEAAV01@ABV01@@Z
?Mf@MyClass@MiniMFC@@QAEXXZ
可见只导出了类的构造函数和成员函数,全局函数f()
没有导出。
实现文件中的函数f()
的定义并未使用名字空间MiniMFC
,所以只得到了全局名字空间的一个名为f
的函数,而头文件中声明的那个MiniMFC
名字空间中名为f
的函数并没有实现代码。我们把.cpp文件中的函数定义改为如下:
__declspec(dllexport) void f()
{
cout << "I‘m MiniMFC::f() from DLL" << endl;
}
然后重新编译,使用Dependency Walker可以看出,这次dll确实导出了名为f
的函数,但是它是全局空间的,不是MiniMFC名字空间里的。
??4MyClass@MiniMFC@@QAEAAV01@ABV01@@Z
?Mf@MyClass@MiniMFC@@QAEXXZ
?f@@YAXXZ
知道了原因,解决起来非常简单,只需要在实现文件中f()
的定义中使用MiniMFC名字空间进行限定。如下所示:
void MiniMFC::f()
{
cout << "I‘m MiniMFC::f() from DLL" << endl;
}
重新编译后,这次得到了正确的结果:
??4MyClass@MiniMFC@@QAEAAV01@ABV01@@Z
?Mf@MyClass@MiniMFC@@QAEXXZ
?f@MiniMFC@@YAXXZ
原文地址:http://blog.csdn.net/smstong/article/details/44338837