我不太需要一个列表类型来保存命名结构,而这些结构依次是一个相同类型的任意数量的成员,由指针表示。完整的项目代码使用Qt(如果这很重要)。
所以我写了这个:
/*
* This should be used with T as a pointer type.
* Code gets really incomprehensible if T* value is used as member.
*/
template <typename T>
struct parameter_t {
QString name;
int count;
T value;
};
template <typename T>
class Parameters {
private:
typedef struct parameter_t< T > content_t; // beautification
public:
void addParam(const QString &name, T value, int count);
private:
std::list< content_t >* params;
};
typedef Parameters<float*> floatParameters; // beautification
对我来说似乎不仅仅是合法的,因为实际的实现确实可以编译无错误的东西。
现在,从另一个地方,我打电话给以下人员:
floatParameters* params = new floatParameters();
params->addParam("Ente", (float*) x, 1);
这会导致编译器错误,包括:
In function `...': HelperClasses.cc:(.text+0x225): undefined reference to Parameters<float*>::addParam(QString const&, float*, int)'
你可以清楚地看到,我正在创建floatParameters,所以它是参数。换句话说,addParam成员应该转换为
void addParam(const QString &name, float* value, int count);
为什么我收到此错误?
答案 0 :(得分:2)
模板函数应该在头文件中定义,而不是源文件。在使用该函数之前,不会构建模板的实际代码,因此该定义必须在此时可用 - 否则编译器会假定链接器稍后可以找到它。