我有一个称为House的结构,它包含一个用于邻域的char数组。我正在尝试读取房屋数据库,并为具有相同邻域的房屋创建数组。读取部分工作正常,但是当我为邻域创建新数组时,我的函数仅进入循环23次,并找到具有相同邻域的前23座房屋,并给出此错误。
pro(4740,0x10d06f5c0)malloc: *对象0x7ff724d00030的错误:正在分配的指针未分配 pro(4740,0x10d06f5c0)malloc:* 在malloc_error_break中设置一个断点进行调试
typedef struct house{
int id;
int lotarea;
char street[5];
int saleprice;
char neighborhood[10];
int yearbuilt;
int overallqual;
int overallcond;
char kitchenqual[3];
} House;
House* get_neighborhoods(House house, House* array) {
printf("Get neighborhoods of house with id %d\n", house.id);
House* temp = array;
int counter = 1;
House* newarray = malloc(sizeof(House));
if (newarray == NULL) {
printf("Malloc error...");
}
while (temp != NULL) {
if (!strcmp(temp->neighborhood, house.neighborhood)) {
if (counter > 1) {
realloc(newarray, sizeof(House) * counter);
}
copy_house(newarray + counter - 1, temp);
print_house(newarray[counter - 1]);
counter++;
}
temp++;
}
return newarray;
}
答案 0 :(得分:2)
您必须分配来自realloc
的返回值。你有
realloc(newarray, sizeof(House) * counter);
调用它的 second 时间(在循环中),先前传递给它的指针已经free
d,但是您丢弃了新值。
newarray = realloc(newarray, sizeof(House) * counter);
理想情况下,您应该将返回值分配给一个临时变量,以便检查realloc
是否成功。