问题表明我需要两种结构,STRUCTURE1和STRUCTURE2(我知道原始结构)。STRUCTURE1 包含 5 个浮点值(不是数组)和一个指针。STRUCTURE2保存 1 个浮点值和一个指向另一个STRUCTURE2类型的指针。我还需要一个指针数组,其中每个元素都指向一个STRUCTURE1。然后每个前STRUCTURE1指向另一个STRUCTURE1,但随后该STRUCTURE1需要指向一个STRUCTURE2(这就是类型转换的用武之地)。
下面是我代码的重要部分,问题(至少我得到错误的地方)在 printToFile() 中,在我遇到分段错误的trav2 = (STRUCT2*)trav1->next;
部分。
void main(){
STRUCT1 *ptr[20] = {NULL}; //Array of pointers that point to type STRUCT1
float min, max;
int i, j, answer;
for(i = 0; i < 19; i++){ //19 to leave the 20th array spot for NULL
printf("nWould you like to add 2 more sets of numbers?n");
printf("1: Yesn");
printf("2: Non");
scanf("%d", &answer);
if(answer == 1){
printf("nFirst set of numbers:n");
ptr[i] = getData();
printf("nSecond set of numbers:n");
ptr[i]->next = getData();
min = getMin(ptr[i]);
max = getMin(ptr[i]->next);
STRUCT2 *trav;
trav = (STRUCT2*)malloc(sizeof(STRUCT1));
trav = (STRUCT2*)ptr[i]->next;
trav->next = assignMin(min);
trav = trav->next;
trav->next = assignMax(max);
}else{
break;
}
}
printToFile(ptr);
printf("nProgram Donen");
}
STRUCT1* getData(){
STRUCT1 *newStruct;
newStruct = (STRUCT1*)malloc(sizeof(STRUCT1));
float num;
printf("Enter number 1: ");
scanf("%f", &num);
newStruct->f1 = num;
printf("Enter number 2: ");
scanf("%f", &num);
newStruct->f2 = num;
printf("Enter number 3: ");
scanf("%f", &num);
newStruct->f3 = num;
printf("Enter number 4: ");
scanf("%f", &num);
newStruct->f4 = num;
printf("Enter number 5: ");
scanf("%f", &num);
newStruct->f5 = num;
return newStruct;
}
void printToFile(STRUCT1 *ptr[]){
FILE *f;
f = fopen("structure.txt", "w");
int i, j;
STRUCT1 *trav1;
STRUCT2 *trav2;
trav1 = (STRUCT1*)malloc(sizeof(STRUCT1));
trav2 = (STRUCT2*)malloc(sizeof(STRUCT2));
for(i = 0; i < 20; i++){
fprintf(f, "%.3f,%.3f,%.3f,%.3f,%.3fn", ptr[i]->f1, ptr[i]->f2, ptr[i]->f3, ptr[i]->f4, ptr[i]->f5);
trav1 = ptr[i]->next;
fprintf(f, "%.3f,%.3f,%.3f,%.3f,%.3fn", trav1->f1, trav1->f2, trav1->f3, trav1->f4, trav1->f5);
trav2 = (STRUCT2*)trav1->next;
fprintf(f, "Minimum of first number set: %.3fn", trav2->f1);
trav2 = trav2->next;
fprintf(f, "Maximum of second number set: %.3fn", trav2->f1);
fprintf(f, "n");
}
}
这可能非常非常错误,但我的教授从未谈论过指向不同类型的指针,而且关于结构的部分也很短。希望它不是完全拙劣的,只需要这里和那里的一些东西。
有人认为他们看到了哪里出了问题吗?
问题中没有足够的信息,缺少填充这些结构的结构定义和代码。演员阵容不一定是错的。但是,您可以使用不同的指针来访问任一类型的结构:
if (ptr->next_st1 != NULL) {
trav1 = ptr->next_st1;
} else if (ptr->next_st2 != NULL) {
trav2 = ptr->next_st2;
}
作为旁注,您在此处执行的分配:
trav1 = (STRUCT1*)malloc(sizeof(STRUCT1));
trav2 = (STRUCT2*)malloc(sizeof(STRUCT2));
for(i = 0; i < 20; i++){
/* ... */
trav1 = ptr[i]->next;
/* ... */
不是必需的,因为您要将指针分配给已分配的区域 ( trav1 = ptr[i]->next
)。由于此分配,您正在泄漏内存,因为您丢失了指向错误定位块的指针。在这种情况下,malloc
不是必需的,但是在必要时,您应该进行相应的free()
呼叫。
我认为你的问题出在这一行:
trav = (STRUCT2*)malloc(sizeof(STRUCT1));
在这里,tray
作为STRUCT2
指针并为STRUCT1
分配内存。更好地使用sizeof(STRUCT2)
。