对于一个赋值,我必须编写一个循环队列(我想你们大多数人都很熟悉)。我制作了一个使用动态内存初始化队列结构的结构和函数。请注意,我在为其分配内存的结构中还有一个数组arr。
出于某种原因,我似乎无法将我的数组从内存中解放出来。
struct queue {
element_t *arr; // dynamic array containing data elements
int current_size; // Counts number of elements in the queue
int front, rear; // Remark for later: extra fields need to be added here to make it a thread-safe queue as needed for the assigment
};
queue_t* queue_create(){
struct queue *queue = malloc(sizeof(struct queue));
if(queue == 0){ //check if memory available
printf("Out of memoryn");
return NULL;
}
queue -> current_size = 0;
queue -> front = -1;
queue -> rear = -1;
queue -> arr = malloc(QUEUE_SIZE*sizeof(element_t));
return queue;
}
当我使用函数queue_free处理完内存后,我正试图释放内存。函数接收一个指向队列的双指针(赋值的一部分)。
void queue_free(queue_t** queue){
free(**queue -> arr);
free(*queue);
}
当我调用最后一个函数时,我收到一条错误消息,上面写着:
queue.c: In function ‘queue_free’:
queue.c:39:16: error: request for member ‘arr’ in something not a structure or union
free(**queue -> arr);
^
我已经和valgrind核实过是否有泄漏。队列被正确释放,但由于某种原因,我无法获得数组的地址。
提前感谢
p.S.空闲(队列->arr);空闲(*queue->arr);和空闲(**queue->arr);所有都失败并生成相同的错误消息。
free语句应该看起来像free((*queue)->arr)
。
说明:queue_free
将queue
变量定义为指向queue_t
结构的指针。现在,为了获得指向结构的指针,您需要使用(*queue)
删除一个间接级别;则可以使用解引用运算符->
来访问arr
成员。
现在,其他选项不适用于您的原因是:
free(queue -> arr)
-指向queue_t结构的指针的指针没有arr
成员free(*queue -> arr)
-解引用运算符('*'
)指代整个表达式,即queue->arr
,它将带您返回到上一个错误free(**queue -> arr)
-同上