我正在尝试删除结构条目,然后使用realloc
释放内存。我的结构是
typedef struct person {
char fname[20];
char lname[20];
int number[10];
}person;
我使用函数删除输入的条目
void delInfo(int*,person*);
删除功能的工作方式是找到所述条目,然后将所有记录移回,然后用realloc
释放最后一条记录。
到目前为止它的代码看起来像这样
void delInfo(int *num_entries,person*contacts){
char delfirst[20];
char dellast[20];
printf("\n First Name: ");
scanf("%s",delfirst);
printf(" Last Name: ");
scanf("%s",dellast);
int i=0;
for (i=0; i<*num_entries;i++){
if (delfirst==contacts[i].fname && dellast==contacts[i].lname){
}
}
}
到目前为止,我可以搜索与名字和姓氏匹配的内容,但不知道如果我将每个条目“向下移动”会发生什么。如果匹配条目是联系人[i]类似
int c;
for (c=i+1;c<*num_entries;c++){
contacts[i].fname=contacts[c].fname;
contacts[i].lname=contacts[c].lname;
contacts[i].number=contacts[c].number;
}
contacts=(person*)realloc(contacts,sizeof(contacts)*(num_entries-1));
如果我对我计划删除的所有条目执行此操作,是否只是“覆盖”我要删除的条目,那么我可以realloc
缩短结构数组并基本上释放内存?
答案 0 :(得分:0)
如果i
是您要删除的条目的索引,那么您真正需要做的就是:
for (c = i; c < *num_entries - 1; c++)
contacts[c] = contacts[c+1];
然后您可以重新分配较小的动态数组。结构可以分配给兼容的结构,因此您不需要单独分配结构的字段。