Неопределенная ссылка на функцию шаблона
У меня есть три файла. Содержимое 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
Что-то не так с объявлением или реализацией шаблона? почему M I получает эти ошибки связывания:?
2 ответа
Реализация неспециализированного шаблона должна быть видима для модуля перевода, который его использует.
Компилятор должен видеть реализацию, чтобы генерировать код для всех специализаций в вашем коде.
Это может быть достигнуто двумя способами:
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);
}
}
У вас есть 2 способа:
Воплощать в жизнь
convert2QString
в утих.ч.Инстанцировать вручную
convert2QString
сint
в util.cpp и определите эту специализацию как внешнюю функцию в util.h
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);
}