我的程序是通过创建具有新大小的新 arr 来增加结构数组的大小,然后将旧数组的双指针分配给新数组。在将旧数组分配给新数组之前或之后,我一直在努力释放旧数组的内存。如果我不收费(),它会给出正确的结果,否则,它会自动拾取并打印出一些垃圾值。请帮忙,谢谢。
*不允许重新分配。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct car {
char name[30];
int quantity;
};
void increaseSize(int *cap, int size, struct car **carArray) {
printf("cap = %d size = %d\n", *cap, size);
*cap *= 2;
printf("cap x 2 = %d\n", *cap);
struct car *newCarArray = (struct car * ) malloc(*cap * sizeof(struct car));
memcpy(newCarArray, carArray, sizeof(struct car));
free(*carArray); // If I free old carArray here, it will give incorrect results. How can I release/clear/delete/free the memory of the old array here?
carArray = &newCarArray;
printf("increased cap = %d size = %d\n", *cap, size);
}
void printArray(int cap, int size, struct car *carArray) {
printf("Capacity = %d, Size = %d \n", cap, size);
for(int i = 0; i < size; i++) {
printf("Car %d, Name: %s, Quantity: %d\n", i, carArray[i].name, carArray[i].quantity);
}
}
int main() {
int cap = 2;
int size = 0;
struct car *carArray = (struct car *) malloc(cap * sizeof(struct car));
struct car car_0 = {"Corolla", 5};
carArray[0] = car_0;
size++;
struct car car_1 = {"Accord", 8};
carArray[1] = car_1;
size++;
printArray(cap, size, carArray);
increaseSize(&cap, size, &carArray);
struct car car_2 = {"Forte", 3};
carArray[2] = car_2;
size++;
printArray(cap, size, carArray);
free(carArray);
return 0;
}
最佳答案
这里有两个问题。
首先,您仅复制单个结构,而不是整个数组:
memcpy(newCarArray, carArray, sizeof(struct car));
在这里,您所说的是复制 sizeof(struct car)
字节,这对于一个结构来说已经足够了。您也没有复制正确的内容,因为 carArray
是一个指针到指针。您需要乘以原始大小来复制整个数组,并且需要取消引用carArray
:
memcpy(newCarArray, *carArray, (*cap / 2) * sizeof(struct car));
另一个问题在这里:
carArray = &newCarArray;
此处,您仅修改参数 carArray
,因此对其所做的更改不会反射(reflect)在调用方中。您需要像 car
一样取消引用它:
*carArray = newCarArray;
关于c - 在这种情况下如何正确释放双指针的内存?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53191462/