如何修复“未分配指针”的错误

时间:2019-05-20 21:58:44

标签: c malloc realloc

我有一个称为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;

}

1 个答案:

答案 0 :(得分:2)

您必须分配来自realloc的返回值。你有

realloc(newarray, sizeof(House) * counter);

调用它的 second 时间(在循环中),先前传递给它的指针已经free d,但是您丢弃了新值。

newarray = realloc(newarray, sizeof(House) * counter);

理想情况下,您应该将返回值分配给一个临时变量,以便检查realloc是否成功。