对模板函数的未定义引用

我有三个文件,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;
}

工具

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

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

94973 次浏览

非专用模板的实现必须对使用它的翻译单元可见。

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

This can be achieved in two ways:

1)将实现移动到标题内部。

2)如果你想把它分开,把它移动到一个不同的标题,你包括在你原来的标题:

工具

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 中将此专门化定义为 externfunction

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);
}