VC++导出具有命名空间的函数

    • 问题现象
    • 原因分析
    • 解决办法

1 问题现象

导出具有命名空间的函数和类。源代码如下:

头文件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()没有导出。

2 原因分析

实现文件中的函数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

3 解决办法

知道了原因,解决起来非常简单,只需要在实现文件中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

你可能感兴趣的:(VC,dll导出命名空间)