所以,我向用户询问novo-> prato(列表项),但是在函数调用中的某处或者之前的scanf中,程序崩溃了,我看不出代码有什么问题。 / p>
这些是声明和功能。
typedef struct pedido pedido, *ppedido;
struct ingrediente{
char nome[15];
int id;
int qtd;
int limite;
int consumo_medio;
};
struct item{
char id[5];
int ing[10];
float qtd[10];
};
struct pedido{
char id[5];
int prioridade;
int mesa, n_pratos;
struct prato *prato[TAM];
ppedido prox;
};
struct prato{
char id[5];
};
int verifica_prato(char prato[])
{
FILE *f;
struct item aux;
int i=0, j=0;
f = fopen("menu.bin", "rb");
while((fread(&aux, sizeof(struct item), 1, f)) == 1){
if((strcmp(prato, aux.id)) == 0)
i++;
}
fclose(f);
if(i == 0){
printf("Prato nao existe no menu.\n");
return 1;
}
if(i > 1)
return 0;
}
这就是函数ia所称的地方。
for(i=0;i<novo->n_pratos;i++){
do{
printf("Introduza o ID do prato %d: ", i+1);
scanf("%s", &novo->prato[i]);
printf("%s", novo->prato[i]);
k = verifica_prato(novo->prato[i]); //this function
if(k == 0)
w = verifica_ing(novo->prato[i]->id);
}while(k != 0);
}
答案 0 :(得分:3)
内部verifica_prato()
在f = fopen("menu.bin", "rb")
行之后,您应该检查文件是否成功打开
使用if( f != NULL )
答案 1 :(得分:0)
novo->n_pratos
是否始终小于TAM
?如果n_pratos
超过TAM
,则可能存在边界错误,因为TAM
已被定义为数组大小。
答案 2 :(得分:0)
verifca_prato的签名不应该是int verifica_prato(struct prato),或者调用应该是verifica_prato(novo-&gt; prato [i] - &gt; id);