首先是循环队列的声明和初始化:
typedef struct {
int *base;
int front_;
int rear;
}SqQueue;
在某本书上看到这样的初始化:
int InitQueue(SqQueue *Q)
{
Q->base = (int *)malloc(MAXQSIZE*sizeof(int));
if(!Q->base)return -1;
Q->front_ = 0; Q->rear = 0;
return 0;
}
运行这个初始化函数会报错,Process returned -1073741819 (0xC0000005);这个问题一般是由空指针引引起。编译时不会报错,但是在执行该函数时程序会崩。
让我们用一些输出来看看问题在哪里:
int main()
{
SqQueue *T;
cout<<sizeof(SqQueue)<<endl;
cout<<sizeof(int)<<endl;
cout<<sizeof(T)<<endl;
cout<<InitQueue(T);
}
这个是很典型的内存分配出错,而且显然是因为个人忽略了,注意主函数里我并没有为SqQueue的队列分配空间,只是声明而已。正确的代码应该这样写:
SqQueue *T = new SqQueue();
这样就不会再出现内存错误: