调用函数时,C程序崩溃。

时间:2012-06-24 01:27:02

标签: c

所以,我向用户询问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);
}

3 个答案:

答案 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);