因此,我正在尝试弄清在混合使用模板时继承的工作方式。大多数编译器似乎还没有弄清楚这个问题,因此我在语法上有一点困难。 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)
{
}

08-25 08:33