在C ++中使用未声明的标识符以及模板和继承

时间:2012-05-24 10:24:57

标签: c++ templates inheritance

以下代码无法编译 - 使用未声明的标识符。我使用GCC和XCode进行编译。

所有内容都在一个头文件中。

include "MyArray.h"

template <typename T>
class MyBase {
public:
  MyBase();
  virtual ~MyBase();
  void addStuff(T* someStuff);
protected:
  MyArray<T*> stuff;
};

template <typename T>
MyBase<T>::MyBase() {}
template <typename T>
MyBase<T>::~MyBase() {}

template <typename T>
void MyBase<T>::addStuff(T* someStuff) {
  stuff.add(someStuff);
}

// ---------------------

template <typename T>
class MyDerived : public MyBase<T> {
public:
  MyDerived();
  virtual ~MyDerived();
  virtual void doSomething();
};

template <typename T>
MyDerived<T>::MyDerived() {}
template <typename T>
MyDerived<T>::~MyDerived() {}

template <typename T>
void MyDerived<T>::doSomething() {
  T* thingy = new T();
  addStuff(thingy); //here's the compile error. addStuff is not declared.
}

有没有人有解释? 提前谢谢!

4 个答案:

答案 0 :(得分:21)

this->addStuff(thingy);

答案 1 :(得分:5)

有几个问题:

  1. 课程定义后缺少分号。
  2. 缺少doSomething方法声明/定义的类型。
  3. 缺少addStuff方法定义的类型。
  4. 修好it seems to work

    编辑:因为您修复了语法错误,但仍然无效。正如其他人所建议您的编译器可能要求您使用addStuff前缀调用this->方法:

    this->addStuff(thingy);
    

答案 2 :(得分:3)

这是由于模板继承。在这种情况下,您应手动指定使用基本方法:

template <typename T>
MyDerived<T>::doSomething() {
  using MyBase<T>::addStuff;
  T* thingy = new T();
  addStuff(thingy); 
}

或通过此指针执行:

template <typename T>
MyDerived<T>::doSomething() {
  T* thingy = new T();
  this->addStuff(thingy); 
}

答案 3 :(得分:1)

使用此指针调用addStuff方法,即

this->addStuff(thingy);