我正在使用模板和静态成员实现一些想法。虽然“真正的”代码会产生另一个错误,但这是我在玩具示例中仍然存在的错误code
#include <string>
#include <iostream>
template<int dim>
class Class1 {
public:
Class1() {};
~Class1() {};
void foo() {
std::cout<<"foo-1"<<std::endl;
}
protected:
std::string name;
};
template<int dim>
class Class2 : public Class1<dim>
{
public:
Class2(const int & a, const int &b) :
number( Class2<dim>::id_generator++ )
{
Class1<dim>::name = "My-name";
foo(); // (1)
};
void foo() {
Class1<dim>::foo();
std::cout<<"foo-2"<<std::endl;
}
private:
const unsigned int number;
static unsigned int id_generator;
};
int main()
{
int a = 1, b=2;
Class2<2> class2(a,b); // (2)
}
链接器错误:
undefined reference to `Class2<2>::id_generator'
rea-life示例产生2个错误
(1) required from 'Class2<dim>::Class2(int, int) [with int dim = 3]'
(2) required from here.
现实生活中的错误告诉我什么都没有! :( 我希望如果玩具问题得到解决,现实生活中的问题也会消失, 但如果有人对结构背景下的“现实生活”错误(那2行)有任何想法,请告诉我。
答案 0 :(得分:1)
您忘记为static
数据成员id_generator
添加定义。在全局命名空间级别添加:
template<int dim>
unsigned int Class2<dim>::id_generator = 0;
通过此添加,您可以看到代码correctly compiling and linking here。
答案 1 :(得分:1)
好吧,正如错误消息所示,没有静态数据成员的定义。如果这是一个普通的类,你可以将定义放在源文件中:
// header:
class C {
static int i;
};
// source:
int C::i = 3;
模板是一种模式;编译器使用它来生成代码。因此,当编译器实例化模板时,您最终想要的是类似于前面的代码。但是模板代码放在标题中,而不是源文件中,所以你可以这样写:
// header:
template <class T>
class C {
static int i;
};
template <class T>
int C<T>::i = 3;