我必须为这些元素分配和重新分配内存。我试图解决它,但我的解决方案不起作用。有人可以帮忙吗?
typedef struct {
char Name[50];
char Surname[150];
}Teacher;
typedef struct{
int id;
char Title[256];
int numberOfTeachers;
Teacher* teachers;
}Lesson;
typedef struct{
Lesson* arr;
int numberOfLessons;
}Lessons;
答案 0 :(得分:6)
对于一个基本示例,请像这样分配teachers
对象的Lesson
数组:
Lesson lesson;
lesson.numberOfTeachers = 10;
lesson.teachers = malloc(lesson.numberOfTeachers * sizeof(*lesson.teachers));
要解除分配:
free(lesson.teachers);
但您可能还需要动态分配Lesson
个对象。
Lessons lessons;
lessons.numberOfLessons = 5;
lessons.arr = malloc(lessons.numberOfLessons * sizeof(*lessons.arr));
然后你会在一个循环中填充:
for (size_t i=0; i<lessons.numberOfLessons; i++)
{
Lesson *lesson = malloc(sizeof(*lesson));
lesson->numberOfTeachers = 10;
lesson->teachers = malloc(lesson.numberOfTeachers * sizeof(*lesson.teachers));
lessons.arr[i] = lesson;
}
要解除分配:
for (size_t i=0; i<lessons.numberOfLessons; i++)
{
free(lessons.arr[i]);
}
free(lessons.arr);
您还需要填充其余字段,但我会专注于分配并留给您。
在实际代码中,您需要检查调用malloc
的错误的返回值,并做出相应的回应。
重新分配有点棘手。假设您要更改teachers
对象中Lesson
数组的长度。在这一点上,我认为你需要开始在功能中包装。
void SetTeacherCount(Lesson *lesson, int count)
{
Teacher* newTeachers = realloc(lesson->teachers, count*sizeof(*lesson->teachers));
if (newTeachers == NULL)
{
// handle error
}
lesson->teachers = newTeachers;
}
当您重新分配包含也分配了动态内存的元素的数组时,这会变得更加棘手。在重新分配父数组之前,您需要确保free
任何此类嵌套动态分配的内存。