未定义的引用模板函数
我有三个文件。 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); } }
你有两种方法:
-
在util.h中实现
convert2QString
。 -
在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); }