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

これは、関数が呼び出された場所です。

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

verifca_prato のシグネチャを int verifica_prato(struct prato) にするか、呼び出しを verifica_prato(novo->prato[i]->id); にする必要があります。

于 2012-06-24T08:12:25.320 に答える
0

は常に?novo->n_pratosより小さい が配列サイズとして定義されているため、を超えるTAMと境界エラーが発生する可能性があります。n_pratosTAMTAM

于 2012-06-24T01:44:53.507 に答える