1

因此,我向用户询问 novo->prato (一个列表项),但是在函数调用或它之前的 scanf 的某个地方,程序崩溃了,我看不出代码有什么问题。

这些是声明和函数。

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);
}
4

3 回答 3

3

verifica_prato()
该行之后,f = fopen("menu.bin", "rb") 您应该检查文件是否成功打开。
利用 if( f != NULL )

于 2012-06-24T01:49:22.890 回答
0

总是novo->n_pratos小于TAM?如果n_pratos超过TAM,可能会出现边界错误,因为TAM已定义为数组大小。

于 2012-06-24T01:44:53.507 回答
0

verifca_prato 的签名不应该是 int verifica_prato(struct prato) 还是调用应该是 verifica_prato(novo->prato[i]->id);

于 2012-06-24T08:12:25.320 回答