5

在 Visual C++ 中,我可以执行以下操作:

template <class T>
class A{
protected:
    T i;
};

template <class T>
class B : public A<T>{
    T geti() {return i;}
};

如果我尝试在 g++ 中编译它,我会得到一个错误。我必须这样做:

template <class T>
class B : public A<T>{
    T geti() {return A<T>::i;}
};

我不应该在标准 C++ 中做前者吗?还是 gcc 配置错误导致我出错?

4

3 回答 3

6

这曾经是允许的,但在gcc 3.4中改变了。

在模板定义中,非限定名称将不再找到依赖基的成员(如 C++ 标准中的 [temp.dep]/3 所指定)。例如,

    template <typename T> struct B {
      int m;
      int n;
      int f ();
      int g ();
    };
    int n;
    int g ();
    template <typename T> struct C : B<T> {
      void h ()
      {
        m = 0; // error
        f ();  // error
        n = 0; // ::n is modified
        g ();  // ::g is called
      }
    };

您必须使名称依赖,例如通过在它们前面加上 this->。这是 C::h 的更正定义,

    template <typename T> void C<T>::h ()
    {
      this->m = 0;
      this->f ();
      this->n = 0
      this->g ();
    }
于 2008-10-11T21:02:17.547 回答
3

我想出了这个:

显然,第一个示例不是有效的 C++,msvc 采用它很糟糕。C++ faq lite 上发布了解决方案。

于 2008-10-11T21:03:34.813 回答
0

您可能想了解两阶段名称查找

于 2008-10-12T15:09:53.263 回答