【发布时间】:2010-12-21 11:55:26
【问题描述】:
下面的代码可以编译,但由于其他人明显的原因而立即崩溃,但对我来说不是。我似乎无法做到这一点,谁能告诉我如何解决这个问题。
*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;
}
【问题讨论】:
-
在代码有 bug 的情况下,特别是当 bug 是实际崩溃并且每次都发生时,您通常应该做的是尝试将其缩小到最少的代码量仍然让它发生。这将使其他人在查看代码时更容易找到错误,更重要的是,您更容易理解导致崩溃的确切原因。
-
@Edan,我不会说在这种情况下这是一个问题。这里代码不多,问题还算清楚。
-
+1 伊丹。缩小范围以删除
array_ref可以澄清问题,并且肯定会帮助 ZPS 理解它。
标签: c arrays data-structures pointers malloc