84669 Lernen von Personen
152542 Lernen von Personen
20005 Lernen von Personen
5487 Lernen von Personen
7821 Lernen von Personen
359900 Lernen von Personen
3350 Lernen von Personen
180660 Lernen von Personen
48569 Lernen von Personen
18603 Lernen von Personen
40936 Lernen von Personen
1549 Lernen von Personen
1183 Lernen von Personen
32909 Lernen von Personen
小伙看你根骨奇佳,潜力无限,来学PHP伐。
一个不完美的解决办法,显式实例化。例如
templ.h 中
template <typename T> T max (T const& lhs, T const& rhs);
templ.cpp
#include "templ.h" template <typename T> T max (T const& lhs, T const& rhs) { return lhs > rhs ? lhs : rhs; } int max (int const& lhs, int const& rhs); double max (double const& lhs, double const& rhs); string max (string const& lhs, string const& rhs); //...
这样cpp中模板被显式实例化后就不会在链接阶段失败,好处是cpp实现不会暴露给客户,只需提供头文件和库文件。但局限性在于模板的支持的类型是有限的,用户有新增的类型就不支持了。
C++98标准有export关键字来实现模板的声明和实现分离。即:templ.h 中
export template <typename T> T max (T const& lhs, T const& rhs);
#include "templ.h" template <typename T> T max (T const& lhs, T const& rhs) { return lhs > rhs ? lhs : rhs; }
但是鲜有编译器实现这个功能,而且C++11标准中export已经没有这个功能了。
对于模板的实现代码,连微软都是开源的,所以应该是没有啥完美的解决方案了。
如果只有模板,我认为是不可能的,没见过这种纯模板封装在dll里面的样例,模板不是普通的c++代码。。如果自己的算法不想暴露实现,那么唯一的方式就是做成动态库或者静态库以及模板代码两部分,即一部分重要实现搞到库中,不重要的放在模板里面,有点像boost那样子。。
模板基本做不到了,大部分编译器不支持export关键字
一个不完美的解决办法,显式实例化。
例如
templ.h 中
templ.cpp
这样cpp中模板被显式实例化后就不会在链接阶段失败,好处是cpp实现不会暴露给客户,只需提供头文件和库文件。
但局限性在于模板的支持的类型是有限的,用户有新增的类型就不支持了。
C++98标准有export关键字来实现模板的声明和实现分离。
即:
templ.h 中
templ.cpp
但是鲜有编译器实现这个功能,而且C++11标准中export已经没有这个功能了。
对于模板的实现代码,连微软都是开源的,所以应该是没有啥完美的解决方案了。
如果只有模板,我认为是不可能的,没见过这种纯模板封装在dll里面的样例,模板不是普通的c++代码。。
如果自己的算法不想暴露实现,那么唯一的方式就是做成动态库或者静态库以及模板代码两部分,即一部分重要实现搞到库中,不重要的放在模板里面,有点像boost那样子。。
模板基本做不到了,大部分编译器不支持export关键字