未定义的引用模板函数

我有三个文件。 main.cpp的内容是

#include<iostream> #include<QString> #include "util.h" int main() { using Util::convert2QString; using namespace std; int n =22; QString tmp = convert2QString<int>(n); return 0; } 

util.h

 namespace Util { template<class T> QString convert2QString(T type , int digits=0); } 

util.cpp

 namespace Util { template<class T> QString convert2QString(T type, int digits=0) { using std::string; string temp = (boost::format("%1%") % type).str(); return QString::fromStdString(temp); } } 

当我尝试使用以下命令编译这些文件时,出现未定义的引用错误

 vickey@tb:~/work/trash/template$ g++ main.cpp util.cpp -lQtGui -lQtCore -I. -I/usr/local/Trolltech/Qt-4.8.0/include/QtCore -I/usr/local/Trolltech/Qt-4.8.0/include/QtGui -I/usr/local/Trolltech/Qt-4.8.0/include /tmp/cca9oU6Q.o: In function `main': main.cpp:(.text+0x22): undefined reference to `QString Util::convert2QString<int>(int, int)' collect2: ld returned 1 exit status 

模板声明或实现有问题吗? 为什么MI得到这些链接错误:?

使用该模板的翻译单元必须可见。

编译器必须能够看到实现,以便为代码中的所有特化生成代码。

这可以通过两种方式来实现:

1)移动标题内的实现。

2)如果你想保持独立,把它移动到你原来的标题中包含的不同的标题中:

util.h

 namespace Util { template<class T> QString convert2QString(T type , int digits=0); } #include "util_impl.h" 

util_impl.h

 namespace Util { template<class T> QString convert2QString(T type, int digits=0) { using std::string; string temp = (boost::format("%1") % type).str(); return QString::fromStdString(temp); } } 

你有两种方法:

  1. 在util.h中实现convert2QString

  2. 在util.cpp中用int手动实例化convert2QString并在util.h中将此特化定义为extern函数

util.h

 namespace Util { template<class T> QString convert2QString(T type , int digits=0); extern template <> QString convert2QString<int>(int type , int digits); } 

util.cpp

  namespace Util { template<class T> QString convert2QString(T type, int digits) { using std::string; string temp = (boost::format("%1") % type).str(); return QString::fromStdString(temp); } template <> QString convert2QString<int>(int type , int digits); }