2016-03-05 170 views
1

我很新的C++和我试图从他的孩子,其实是一个模板类调用父虚拟方法。我得到以下错误:调用模板类的父方法

dependent-name 'bList<T>::bNode' is parsed as a non-type, but instantiation yields a type 

我已经审查了其他帖子,并尝试了不同的组合,但没有设法解决它。

template <class T> 
class bList { 
    protected: 
     class bNode 
     { 
      // PARENT METHOD: 
      public: 
       virtual void chain() { 
        // do something... 
       } 
     }; 

    protected: 
     virtual bNode* makeNode(T& data) { 
      return new bNode(); 
     } 
}; 

template <class T> 
class cList : public bList<T> { 
    protected: 
     class cNode : public virtual bList<T>::bNode { 

      // CHILD METHOD: 
      public: 
       virtual typename bList<T>::bNode* chain(typename bList<T>::bNode* node) { 
//     if (...) { 
//      return ... 
//     } 
//     else { 
         return bList<T>::bNode.chain(node); // <- error! 
//     } 
       } 
     }; 

    protected: 
     virtual typename bList<T>::bNode* makeNode(T& data) { 
      return new cNode(); 
     } 
}; 
+0

你的意思是'bList :: bNode :: chain(node)'? – Barry

+0

对不起,我在尝试简化代码以便发布时犯了一个错误。原本签名是好的。使用'this-> bList :: bNode :: chain(node);'解决了这个问题,谢谢。 – trrcore

回答

0
template <class T> 
class bList { 
    protected: 
     class bNode 
     { 
      // PARENT METHOD: 
      public: 
      virtual typename bList<T>::bNode* node chain(typename bList<T>::bNode* node) { 
       // do something... 
      } 
     }; 

    protected: 
     virtual bNode* makeNode(T& data) { 
      return new bNode(); 
     } 
}; 

template <class T> 
class cList : public bList<T> { 
    protected: 
     class cNode : public virtual bList<T>::bNode { 

      // CHILD METHOD: 
      public: 
       virtual typename bList<T>::bNode* chain(typename bList<T>::bNode* node) { 
//     if (...) { 
//      return ... 
//     } 
//     else { 

         return this->bList<T>::bNode::chain(node); 
//      } 
       } 
     }; 

    protected: 
     virtual typename bList<T>::bNode* makeNode(T& data) { 
      return new cNode(); 
     } 
}; 

我已经纠正你的问题,并给予适当的回答。你的问题的问题是你没有正确地覆盖该功能。你的连锁函数有不同的签名。