因此,我正在尝试弄清在混合使用模板时继承的工作方式。大多数编译器似乎还没有弄清楚这个问题,因此我在语法上有一点困难。 SkipNode.h中包含的所有怪异内容都是从试图让 eclipse 到停止对我大吼大叫。尝试在SkipNode.h中声明构造函数时,出现语法错误,因此此处的任何帮助将非常有用。
这是node.h
#ifndef NODE_H_
#define NODE_H_
template<class T>
class Node
{
public:
Node(Node<T>* next, Node<T>* prev, T item);
virtual ~Node();
Node* getPrev() { return prev;};
Node* getNext() { return next;};
Node* getItem() { return item;};
void setItem(T item){Node<T>::item = item;};
void setNext(Node* next){Node<T>::next = next;};
void setPrev(Node* prev){Node<T>::prev = prev;};
private:
Node* next;
Node* prev;
T item;
};
这是SkipNode.h,其中skipnode从Node继承。
#include "Node.h"
#include "Node.cpp"
#include "SkipNode.h"
#include "SkipNode.cpp"
template <class T>
class SkipNode: public Node
{
public:
SkipNode(Node<T>* next, Node<T>* prev, Node<T>* child, T item) : Node(next, prev, item);
virtual ~SkipNode();
Node* getChild(){return child;};
void setChild(Node* child){SkipNode::child = child;};
private:
Node *child;
};
#endif /* SKIPNODE_H_ */
最佳答案
Node
是模板,您应该传入模板参数
template <class T>
class SkipNode: public Node<T>
// ^^^
同样,您需要像提供
SkipNode
一样提供member iniatilizer list
构造函数定义。更新:
SkipNode(Node<T>* next, Node<T>* prev, Node<T>* child, T item)
: Node(next, prev, item);
至:
SkipNode(Node<T>* next, Node<T>* prev, Node<T>* child, T item)
: Node(next, prev, item)
{
}