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"
。在不需要完整类型的地方使用前向声明。