Я выполнил простую очередь в C, но при этом выдал ошибку сегментации при попытке получить доступ к Q.front после удаления (см., Например, int main()).Почему эта реализация очереди в C дает ошибку сегментации?
Чтобы быть более точным, то проблема возникает, когда я -
- Епдиеие один элемент.
- Dequeue его.
- Включить один или несколько элементов.
- Попробуйте получить доступ Q.front
Однако программа не дает ошибку сегментации или какую-либо ошибку, когда я -
- Enqueue более чем один элемент.
- Dequeue один раз.
- Задать больше элементов (необязательно)
- Доступ к Q.front успешно.
Так что это моя полная программа -
#include <stdio.h>
#include <stdlib.h> //for malloc
struct qnode
{
int r;
struct qnode *link;
};
typedef struct qnode qNode;
typedef struct
{
qNode *front;
qNode *rear;
int qsize;
}QUEUE;
QUEUE initializeQueue(void)
{
QUEUE q;
q.front = NULL;
q.rear = NULL;
q.qsize = 0;
return q;
}
qNode *createQueueNode(int e)
{
qNode *temp;
temp = (qNode *) malloc(sizeof(qNode));
if(temp == NULL)
{
printf("INSUFFICIENT MEMORY\n");
exit(0);
}
temp->r = e;
temp->link = NULL;
return temp;
}
QUEUE enqueue(QUEUE q, int e)
{
if(q.rear == NULL)
{
q.rear = createQueueNode(e);
q.front = q.rear;
q.qsize++;
}
else
{
q.rear->link = createQueueNode(e);
q.rear = q.rear->link;
q.qsize++;
}
return q;
}
QUEUE dequeue(QUEUE q)
{
qNode *temp;
if(q.front == NULL)
{
printf("queue is empty\n");
exit(0);
}
else
{
temp = q.front;
q.front = q.front->link;
free(temp);
}
q.qsize--;
return q;
}
int main(){
QUEUE Q = initializeQueue();
Q = enqueue(Q, 2);
printf("%d\n",Q.front->r);
Q = dequeue(Q);
Q = enqueue(Q,4);
printf("%d\n",Q.front->r); // This line is giving segmentation fault
return 0;
}
Но как это null, если я выделил еще один элемент после операции dequeue? –
Должен ли Q.front указать на этот новый элемент в очереди? –