Код ниже компилируется, но сразу же падает по причинам, очевидным для других, но не для меня. Кажется, я не понимаю, может ли кто-нибудь сказать мне, как это исправить.Malloc указатель на указатель на массив структур по ссылке
*array_ref[2] = array[0];
*array_ref[3] = array[1];
Он падает на этой части каждый раз.
typedef struct test {
char *name;
char *last_name;
} person;
int setName(person ** array, person ***array_ref) {
*array = malloc (5 * sizeof(person));
*array_ref= malloc(5 * sizeof(person*));
array[0]->name = strdup("Bob");
array[1]->name = strdup("Joseph");
array[0]->last_name = strdup("Robert");
array[1]->last_name = strdup("Clark");
*array_ref[2] = array[0];
*array_ref[3] = array[1];
return 1;
}
int main()
{
person *array;
person **array_r;
setName(&array,&array_r);
printf("First name is %s %s\n", array[0].name, array[0].last_name);
printf("Second name is %s %s\n", array_r[3]->name, array_r[3]->last_name);
while(1) {}
return 0;
}
Что вы обычно должны делать в случае, когда ваш код имеет ошибку, особенно когда ошибка является фактическим сбоем и происходит каждый раз, заключается в попытке сузить ее до наименьшего количества кода, который все еще делает это. Это облегчит для других поиск ошибки при просмотре кода и, что более важно, намного проще ** вы ** понять, что именно вызывает крах. –
@ Эдан, я бы не сказал, что это проблема в этом случае. Здесь не так много кода, и проблема довольно ясна. –
+1 Edan. Сужение этого, чтобы удалить 'array_ref', проясняет проблему и, несомненно, поможет ZPS понять это. – 2009-11-30 00:39:50