3

我有继承的问题。我创建了这个例子来或多或少地展示我的问题。问题是,如果我从公开派生自类的类公开派生,那么我必须一直访问原始类中的受保护成员。但是,当我使用模板时,情况似乎并非如此。

事实上,下面的例子在 where 'n++;' 的行上抱怨 说'n'没有在范围内声明。但是,如果我在没有模板的情况下这样做。代码编译得很好。到底是怎么回事?

#include<iostream>
template<typename T> 
class base{
 protected:
    T n;
 public:
    T getn();
    base();
};

template<typename T>  
T base<T>::getn(){
   return n; 
}

template<typename T> 
base<T>::base(){
   n = 8; 
}

template<typename T> 
class daddy: public base<T>{
protected: 
public:
};

template<typename T>
class granny: public daddy<T>{
protected:
public:
    T plusone();
};

template<typename T> 
T granny<T>::plusone(){ 
    //this->n = this->n + 1;
   n++;
   return n;
}

int main(){
   granny<int> oldmommy;

   int su = oldmommy.getn();   
   std::cout << su << std::endl;
   su = oldmommy.plusone();
   std::cout << "plusone" << su << std::endl;
   return 0;
}

顺便提一句。告诉我是否应该发布没有模板来比较的代码..

4

2 回答 2

3

一个快速的解决方法是this在变量之前应用:

 this->n = this->n + 1;
 return this->n;

原因是编译器不对模板基类成员(n在这种情况下,取决于类型 T)做任何假设,以防基类的部分特化不包括其中一些成员。

于 2013-04-09T02:00:42.183 回答
2

n在这里是一个从属名称。您必须明确指出它的n来源,否则编译器不知道n您指的是哪个(请注意,可能有一些base专业化没有名为 的成员n)。

您可以使用以下方法实现此目的:

this->n;

或者:

base<T>::n;

而不是n在您的代码中。

于 2013-04-09T02:00:35.537 回答