动态链接库中导出模板函数
C++ 支持函数模板,利用函数模板,可以简化我们的程序代码。我在自己的代码中也经常用到函数模板,但是以前一直以为函数模板是要放到头文件中的,否则调用模板函数时,编译器会找不到函数模板的定义。今天闲暇,又翻了翻 C++ Primer,发现我以前的理解是有问题的。模板函数也可以像普通函数那样,将声明放在头文件中,定义放在.cpp 中。这时又想到另一个问题,DLL 中是否可以导出模板函数呢。如果可以的话,就可以将函数的实现代码真正隐藏起来了。经过一番实验,发现是可以的,但是有一些限制。
比如有如下的函数:
- 1
- 2
- 3
- 4
- 1
- 2
- 3
- 4
直接写成下面的样子是不行的。
- 1
- 2
- 3
- 4
- 1
- 2
- 3
- 4
因为 DLL 中想要导出一个函数,必须要生成这个函数的实体。而普通的函数模板在实例化之前是没有实体的。既然没有实例化,我们就人为的实例化它。比如下面这样:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
再次编译,就成功的导出了三个 max 函数。
但是这里要注意,刚开始时我写成了这个样子:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
结果一个函数也没导出来。不知这是 VC2010 的bug 还是特意这么设计的。手里没有其他的C++ 编译器,不知其他的 C++ 编译器上结果如何。
模板函数/类不能导出到动态链接库(DLL)
模板函数在声明的时候, 其实并不存在,函数地址也就无从谈起了,而导出到动态链接库的函数都需要有地址,也就是说——函数模板不具备导出的基本条件。
函数模板在调用时后,有了具体的实现,这个时候才有了地址。 如果要导出,必须将参数类型列表具体化,比如说,有这么一个模板:
template <class T1,class T2>
void fn1(T1 testValue1,T2 testValue2)
{
}
将参数列表具体化
template <int,char*> __declspec(dllexport) void fn1(int testValue1,char* testValue2)