模板和静态对象(未定义的引用和必需的)

时间:2013-03-30 14:01:54

标签: c++ oop templates c++11

我正在使用模板和静态成员实现一些想法。虽然“真正的”代码会产生另一个错误,但这是我在玩具示例中仍然存在的错误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行)有任何想法,请告诉我。

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;