Possible Duplicate:
Why should the implementation and the declaration of a template class be in the same header file?




希望你能帮助我。

我知道这个问题(经过Google搜索后)已经被问过无数次了。我确定问题的解决方案是在数百万个问题中的一个,但是我找不到它,所以我决定问。

我特别收到此错误:


  错误1错误C2512:'NodeQueue':没有适当的默认构造函数可用a:\ work \ fast \ semi 5 \ automata \ assignments \ progass1 \ progass1 \ progass1 \ tree.h 33 1 progass1


该特定行具有以下定义:

level=new NodeQueue<Node>;


在下一行中也得到相同的错误,但原因是相同的。

我有所有问题的默认构造函数,不确定为什么会发生这种情况。这是部分代码:

头文件的顶部:

#include <iostream>
using namespace std;

#include "intarr.h"
class Node;
template <typename t>
class QueueNode;

template <typename t>
class NodeQueue;


树:

class Tree{

    Node* root;


    int level_length;
    Node* curr;
    NodeQueue <Node>* level,*level_bak;
public:

    Tree(){
        root=NULL;
        level_length=0;
        curr=NULL;
        level=new NodeQueue<Node>;
        level_bak=new NodeQueue<Node>;
    }
// I doubt you need the rest...


类节点

class Node{
public:
    Node *top,*right,*bottom,*left,*prev;
    Node *a,*b,*c;
    int row,col;
    Node(){

    }
    Node(int x,int y){
        top=right=bottom=left=prev=NULL;
        row=x;col=y;
        a=b=c=NULL;
    }

};


queuenode(即队列的节点)

 template <typename t>
     class QueueNode {
     public:
        QueueNode* next;
        QueueNode* prev;

        t *value;
        QueueNode(){

        }
        QueueNode(t* value){
            next=NULL;
            this->value=value;
        }

    };


节点队列:

 template <typename t>
 class NodeQueue {
    QueueNode *head;
    QueueNode *tail;

    //lhs=bottom;

 public:
     NodeQueue(){
        head=NULL;
        tail=NULL;
    }
//....... rest of the code you dont need

最佳答案

由于这是编译器错误(与大多数模板错误问题一样,不是链接器错误),所以我猜测是因为您正向声明了类型:

template <typename t>
class NodeQueue;


您为什么要向前声明它而不包括文件?要构造一个对象,您需要完整的定义,所以#include "NodeQueue.h"

在不需要完整类型的地方使用前向声明。

10-04 16:41